相关疑难解决方法(0)

2454
推荐指数
25
解决办法
111万
查看次数

C++中的位数组

在使用Project Euler问题时,我经常需要大型(> 10**7)位数组.

我的正常方法是:

bool* sieve = new bool[N];

bool sieve[N];
Run Code Online (Sandbox Code Playgroud)

当N = 1,000,000时,我的程序使用1兆字节(8*1,000,000位).

在c ++中使用存储位数组是否比bool更有效?

c++ arrays bit

20
推荐指数
3
解决办法
4万
查看次数

如何在C/Objective C中实现位数组

iOS/Objective-C:我有一大堆布尔值.

这是存储这些值的低效方法 - 当只需要一个时,每个元素至少使用8位.

我该如何优化?

c objective-c core-foundation bitarray ios

12
推荐指数
3
解决办法
9212
查看次数

如何在C++中存储位数组?

在C++中存储位数组的最佳方法是什么(没有Boost,只是标准容器),例如,表示卷分配位图?

我认为这std::vector<bool>是一个好主意,但显然它是邪恶和弃用,所以有更好的选择吗?

也:

如果我在内存中有一个字节数组,我该如何将它们复制到推荐的容器中?
(我很难搞清楚这一点vector<bool>.)

c++ containers stl bitmap bitarray

12
推荐指数
1
解决办法
1万
查看次数

使用枚举定义单个值的优点?(C)

最近,在这个问题中,我看到一个用于定义单个值的枚举.例如:

enum { BITS_PER_WORD = 32 };
Run Code Online (Sandbox Code Playgroud)

代替:

#define BITS_PER_WORD 32
Run Code Online (Sandbox Code Playgroud)

假设以后不会添加更多成员,那么这样做的好处是什么?(或者这是个人品味的问题)

换句话说,如果我有使用one-off int定义的现有代码,是否有任何理由改变上面显示的一次性枚举?

出于好奇,我将GCC的优化汇编程序输出与一些非平凡的代码进行了比较,结果在枚举/定义之间保持不变.

c c-preprocessor

6
推荐指数
2
解决办法
694
查看次数