C++向量的 2D 数组是否适合跟踪 2D 数组的动态域值?
Is a 2D array of C++ vectors suitable for keeping track of a 2D array's dynamic domain values?
用CSP算法编写C++回溯程序,解决数独难题。
变量被映射到9X9网格(81个变量),因此程序是面向行/列的。
为了使回溯更智能,程序需要跟踪9X9网格上每个变量仍然可以接受的可能值。
(对于81个变量中的每一个,数字列表都是1-9,并且不断变化。)
我最初的想法是使用向量的2D数组来映射到每个变量。
例如,向量[1][5]将包含变量[1][5]的所有可能值。
就效率和易用性而言,这是合适的容器还是其他容器效果更好?
为此使用std::vector
听起来不必要而且过于夸张。由于你知道变量的确切域,而且只有数字1-9,我建议使用二维数组,其中每个位置都作为位图。
代码样本(未测试):
short vector[9][9] = { 0 };
/* v must be in the range [1-9] */
void remove_value(int x, int y, int v) {
vec[x][y] |= 1 << v;
}
int test_value(int x, int y, int v) {
return (vec[x][y] & (1 << v));
}
int next_value(int x, int y) {
int res = 1;
for (int mask = 2;
mask != (1 << 10) && (vector[x][y] & mask);
mask <<= 1, res++)
; /* Intentionally left blank */
return res;
}
将vector[x][y]
视为初始化为0:的二进制整数
...0000000000
其含义是,位i
设置为1意味着您已经测试了数字i
,否则,您还没有测试它。比特计数,和往常一样,从右到左,从0开始。您将只使用位1到9。
每次测试完一个新值(也就是说,从域中删除这个值)时,都应该调用remove_value()
,test_value()
可以用来检查v
是否已经过测试——如果v
还没有使用,它会返回0,否则会返回不为0的值(准确地说,是1 << v
)。next_value()
将为您提供按升序排序的位置[x,y]的下一个测试值,如果1-9范围内的每个值都已测试,则为10。
相关文章:
- 2D数组来自文本输入,中间有空格
- 如何使用用户输入在C++中正确填充2D数组
- 如何在C++中检查2D数组中负值的输入验证
- 当我在main中声明了我的2d数组时,为什么我的程序会退出
- 如何将以逗号和空格分隔的整数读取到 2D 数组中?
- 如何在C++函数中声明静态 2D 数组?
- 如何声明一个可以在整个程序中使用的全局 2d 3d 4d .. 数组(堆版本)变量?
- 我已经阅读了很多关于 2d 数组的信息,但我在作业中使用它时遇到了麻烦
- 使用矢量将文本文件中的输入存储到 2D 数组中
- 获取 2D 数组 c++ 中的所有数字对
- 这是使用回溯的 nqueen 问题,但我使用了动态 2d 数组,我的程序编译良好,但不返回任何输出
- 如何在构造函数中使用初始值设定项设置具有相同值的 2d 数组?
- 在 Python 和 c++ 2d 数组初始化之间.这是怎麽?为什么呢?
- 如何打印 2D 字符数组C++
- 如何将数组 2d 作为参数从函数传递并返回数组 2d 此函数
- 数组 2D 多个值
- 创建数组数组 (2D),而无需在 Java 中初始化内部数组
- 如何在C++中将文本文件传输到数组2D
- 从同一类的另一个方法调用数组2D-C++
- 获取地址在数组2d中的位置