我已决定使用STL清单,尽管我们的讲师一直在教我们一个由本书制成的清单。我进行此更改是因为书中的头文件对我不起作用,很可能是我的错。因此,在在线研究之后,我尽了最大的努力来了解STL列表的迭代器是如何工作的。以下是我制作的打印由类型list<list<string>>定义的链表x的代码。

  list < list <string>> x;

while (!inData.fail())
{
    //...
    string str(cstr);//cstr at this point is the sorted string
    bool match = false;
    list <string> inner_list;
    inner_list.push_back(str);
    list<list <string>>::const_iterator cit;
    for (cit = x.begin(); !match && cit !=x.end(); advance(cit,1))
    {
        if (*cit == inner_list)
        {
            inner_list.push_back(temp2); //temp2 is unsorted string
            match = true;
        }
    }

    if (match ==false) x.push_back(inner_list);


}

//printing


list<list <string>>::const_iterator it;
    list<string>::const_iterator it2;
    for (it = x.begin(); it != x.end(); it++)
    {
        for (it2 = it->begin(); it2 != it->end(); it2++)
        {
            cout << *it2 << " ";
        }

    }


我收到列表迭代器取消引用错误,但是我不知道为什么。我将不胜感激任何帮助或提示。如果有任何不清楚或需要解释的地方,请告诉我。

最佳答案

您可以使用以下代码。希望这会帮助你。谢谢。

typedef long long ll;

ll N,M;
string str;
list<string> innerList;
list<list<string> > Data;

cin >> M; // M holds the no. of nodes containing linked list of strings //
for(ll i=0; i<M; i++){
    getchar();
    cin >> N; // No. of strings containing in inner linked list
    getchar();
    for(ll i=0; i<N; i++){
        cin >> str;
        innerList.push_back(str);
    }

    Data.push_back(innerList);
    innerList.clear();
}

// print data //

for(list<list<string> >::iterator it = Data.begin(); it!=Data.end(); it++){
    for(list<string>::iterator iit = (*it).begin(); iit!=(*it).end(); iit++){
        cout << (*iit) << "  " ;
    }
    cout << "\n";

}

关于c++ - 如何打印由另一个字符串链接列表组成的链接列表?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/26072651/

10-11 22:21
查看更多