我正在尝试使用具有递增数字的单元格生成二次网格。
#include <iostream>
#include <vector>
class Simple
{
public:
Simple(): id(genId()) {}
static int genId()
{
static int g_id = 0;
return ++g_id;
}
int id;
};
typedef std::vector< std::vector<Simple> > SimpleGrid;
void printSimpleGrid(SimpleGrid& grid)
{
for(int i = 0; i < grid.size(); i++) {
for(int j = 0; j < grid[i].size(); j++) {
std::cout << grid[i][j].id << " ";
}
std::cout << std::endl;
}
}
int main()
{
int dim = 3;
SimpleGrid test(dim);
for (int i=0; i<dim; i++) {
std::vector<Simple> row(dim);
test[i] = row;
}
printSimpleGrid(test);
return 0;
}
我得到了这个输出:
1 1 1
2 2 2
3 3 3
与我的预期不同:
1 2 3
4 5 6
7 8 9
我做错了什么?
(我正在使用Code :: Blocks 12.11 rev 8629 with SDK version 1.13.14)
答案 0 :(得分:8)
旧版/ C ++ 03编译器会看到这个......
std::vector<Simple> row(dim);
...并将它与构造函数的这个重载相匹配......
explicit vector( size_type count,
const T& value = T(),
const Allocator& alloc = Allocator());
...为第二个构造函数参数创建一个原型Simple
对象,然后将其复制到每个dim
向量元素。
较新的/ C ++ 11编译器将匹配此重载......
explicit vector( size_type count );
...然后继续调用构造函数dim
次来创建元素。
详情here
答案 1 :(得分:1)
除了Tony D's great answer之外,还有 happy end 。在IDE设置中,我为编译器启用了C ++ 11合规性。 Code :: Blocks 12.11包显然不仅支持一种标准: