在c+中使用带列表的迭代器时遇到问题+; 我正在编写一个算法,它检查C++中的检查程序中的重复动作,但是我在使用迭代器< /> >时存在问题。
这是我的密码:在c+中使用带列表的迭代器时遇到问题+; 我正在编写一个算法,它检查C++中的检查程序中的重复动作,但是我在使用迭代器< /> >时存在问题。,c++,list,multidimensional-array,iterator,C++,List,Multidimensional Array,Iterator,这是我的密码: static std::list<char[8][8]> duplicates; char checkForDuplicates[8][8]; for(char i = 0;i < 8;i++) for(char j = 0;j < 8;j++) checkForDuplicates[i][j] = board[i][j]; bool isDuplicate = false;
static std::list<char[8][8]> duplicates;
char checkForDuplicates[8][8];
for(char i = 0;i < 8;i++)
for(char j = 0;j < 8;j++)
checkForDuplicates[i][j] = board[i][j];
bool isDuplicate = false;
for(std::list<char[8][8]>::iterator it = duplicates.begin(); it != duplicates.end(); it++)
{
for(char i = 0;i < 8;i++)
{
for(char j = 0;j < 8;j++)
{
if(checkForDuplicates[i][j] != it->[i][j])
//do something
}
}
}
我试图将列表中的一个数组元素与另一个数组元素进行比较,但我不知道如何使用
列表迭代器
访问列表中的数组元素。有谁能帮我举个例子和/或提些建议吗?不要使用it->[i][j]
使用(*it)[i][j]
。->
符号仅在您访问成员时使用,但您的列表包含数组,而不是类或结构。而不是it->[i][j]
使用(*it)[i][j]
。->
符号仅在访问成员时使用,但列表包含数组,而不是类或结构。如果从迭代器创建对对象的引用,可能更容易理解。之后,您可以按正常方式访问它
static std::list<char[8][8]> duplicates;
char checkForDuplicates[8][8];
for(char i = 0;i < 8;i++)
for(char j = 0;j < 8;j++)
checkForDuplicates[i][j] = board[i][j];
bool isDuplicate = false;
for(std::list<char[8][8]>::iterator it = duplicates.begin(); it != duplicates.end(); it++)
{
char (&thisBoard)[8][8] = *it; # <--
for(char i = 0;i < 8;i++)
{
for(char j = 0;j < 8;j++)
{
if(checkForDuplicates[i][j] != thisBoard[i][j])
//do something
}
}
}
静态标准::列出重复项;
char checkForDuplicates[8][8];
对于(字符i=0;i<8;i++)
对于(字符j=0;j<8;j++)
支票一式两份[i][j]=董事会[i][j];
bool isDuplicate=false;
对于(std::list::iterator it=duplicates.begin();it!=duplicates.end();it++)
{
char(&thisBoard)[8][8]=*it;#如果您从迭代器创建对对象的引用,可能会更容易理解。之后,您可以按正常方式访问它
static std::list<char[8][8]> duplicates;
char checkForDuplicates[8][8];
for(char i = 0;i < 8;i++)
for(char j = 0;j < 8;j++)
checkForDuplicates[i][j] = board[i][j];
bool isDuplicate = false;
for(std::list<char[8][8]>::iterator it = duplicates.begin(); it != duplicates.end(); it++)
{
char (&thisBoard)[8][8] = *it; # <--
for(char i = 0;i < 8;i++)
{
for(char j = 0;j < 8;j++)
{
if(checkForDuplicates[i][j] != thisBoard[i][j])
//do something
}
}
}
静态标准::列出重复项;
char checkForDuplicates[8][8];
对于(字符i=0;i<8;i++)
对于(字符j=0;j<8;j++)
支票一式两份[i][j]=董事会[i][j];
bool isDuplicate=false;
对于(std::list::iterator it=duplicates.begin();it!=duplicates.end();it++)
{
char(&thisBoard)[8][8]=*it;#我认为不能在std::list
中存储数组,因为数组类型不可复制构造或分配,所以在STL容器中存储类型需要两个条件。不过,也许他们在C++11中放宽了这一要求。我认为不能在std::list
中存储数组,因为数组类型不是复制C在可构造或可分配的情况下,在STL容器中存储类型需要两个要求。不过,也许他们在C++11中放宽了这一要求。