繁体   English   中英

迭代器数组c ++中的一组

[英]iterator a set in array c++

#include <iostream>
#include <unordered_set>

using namespace std;
void arraySet(unordered_set<int> n[]){
    for(auto it1 = n->begin(); it1!= n->end(); it1++){
        cout << "n[" <<*it1<<"]: ";
        // for(auto it = it1->begin(); it!= it1->end(); it++){
        //     cout << *it <<" ";
        // }
        cout << endl;
    }
}
int main()
{
    unordered_set<int> n[3];
    n[0].insert(734);
    n[0].insert(23);
    n[0].insert(634);
    n[1].insert(2);
    n[1].insert(1);
    n[2].insert(1);
    arraySet(n);

    return 0;
}

谁能帮我解释一下如何迭代数组中的该集合。 我相信一种简单的方法是将其转换为矢量集。

数组的大小也需要传递给函数,以便您能够遍历数组的所有sets 仅通过传递指针就无法确定大小,并且取消引用n->begin只会迭代第一组。

void arraySet(unordered_set<int> n[], int size) {
    for (auto i = 0; i < size; i++) {
        for (auto it1 = n[i].begin(); it1 != n[i].end(); it1++) {
            cout << "n[" << *it1 << "]: ";
            // for(auto it = it1->begin(); it!= it1->end(); it++){
            //     cout << *it <<" ";
            // }
            cout << endl;
        }
    }
}
int main()
{
    unordered_set<int> n[3];
    n[0].insert(734);
    n[0].insert(23);
    n[0].insert(634);
    n[1].insert(2);
    n[1].insert(1);
    n[2].insert(1);
    arraySet(n,3);

    return 0;
}

或者,您可以使用std::vector包含集合并传递它。

std::vector<unordered_set<int>> n(3); // Sets the size to 3 elements

函数定义将更改为

void arraySet(std::vector<unordered_set<int>>& n) {
    for (size_t i = 0; i < n.size(); i++) {
        for (auto it1 = n[i].begin(); it1 != n[i].end(); it1++) {
            cout << "n[" << *it1 << "]: ";
            // for(auto it = it1->begin(); it!= it1->end(); it++){
            //     cout << *it <<" ";
            // }
            cout << endl;
        }
    }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM