如何打印由另一个字符串链表组成的链表?

时间:2014-09-27 08:06:10

标签: c++ list

我决定使用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 << " ";
        }

    }

我得到一个列表迭代器解除引用错误,但我不知道为什么。我将不胜感激任何帮助或提示。如果有什么不清楚或需要解释请告诉我。

1 个答案:

答案 0 :(得分:1)

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

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";

}