我想要这样的事情:
{ {0,1},{0,2},{0,3},{0,4}...... {255,255} } ---> (1)
经过一些处理后,我必须得到这样的东西:
{ {0,1},{0,2},{0,3} }
{ {0,4} }
{ {5,6},{255,255} }
因此,最初一个大集包含许多子集。每个子集由两个值组成。经过一些处理后,(1)中的一个大集合如上所述进行分解。
现在我想迭代(1)中的集合,并从包含两个元素的每个子集中获取每个值。
这是我的代码。请指导我如何提取子集值。
CrtBestPartitionDouble 对应于由子集组成的大集。 子组是包含两个元素的子集 doublegroup 是一个由所有子集组成的集合
vector<set<vector<int> > > CrtBestPartitionDouble;
vector<set<vector<int> > > ::iterator itr;
set<vector<int> > doublegroup;
set<vector<int> >::iterator itr2;
vector<int>::iterator itr3 ;
for(int k=0; k <5; k++)
{
for(int j=0; j <5; j++)
{ vector<int> subgroup;
subgroup.push_back(k);
subgroup.push_back(j);
doublegroup.insert(subgroup);
}
}
CrtBestPartitionDouble.push_back(doublegroup);
for ( itr = CrtBestPartitionDouble.begin(); itr != CrtBestPartitionDouble.end(); ++itr ) {
// Iterate each set
for ( itr2 = itr->begin(); itr2 != itr->end(); ++itr2 ) {
// Iterate each subset
for ( itr3 = itr2->begin(); itr3 != itr2->end(); ++itr3 ) {
std::cout << *itr3;
}
}
}
它给了我以下错误:
ST.cpp: In function ‘void StateTableGenerator()’:
ST.cpp:460:39: error: no match for ‘operator=’ in ‘itr3 = itr2.
答案 0 :(得分:1)
您可以使用此代码迭代所有值,我不确定这是否是您想要的
typedef vector<set<set<int> > > CrtBestPartitionDoubleType;
CrtBestPartitionDoubleType CrtBestPartitionDouble;
// Iterate each vector element
for ( CrtBestPartitionDoubleType::iterator itr = CrtBestPartitionDouble.begin(); itr != CrtBestPartitionDouble.end(); ++itr ) {
// Iterate each set
for ( set<set<int> >::iterator itr2 = itr->begin(); itr2 != itr->end(); ++itr2 ) {
// Iterate each subset
for ( set<int>::iterator itr3 = itr2->begin(); itr3 != itr2->end(); ++itr3 ) {
std::cout << *itr3;
}
}
}
答案 1 :(得分:1)
范围基于:
for(const auto& a: CrtBestPartitionDouble))
{
for(const auto& b: a)
{
for(const auto& c: b)
std::cout << c;
{
}