我不明白为什么我的代码没有插入到列表中。
但是如果我通过执行 push_back 更改我使用插入的行,该元素将插入到列表中。谢谢
但我必须对它进行排序。运算符 < 得到很好的实现:
void Movies::afegirPeliculaDirector(string director,string title,int year){
list<actorDirectorMovie> llista;
actorDirectorMovie dir(title,year);
int total=_mapDirectors.count(director);
if (total>0){
map<string,list<actorDirectorMovie> >::iterator
it=_mapDirectors.find(director);
llista=(*it).second;
list<actorDirectorMovie>::iterator itList=(*it).second.begin();
while(itList!=(*it).second.end() and (*itList) < dir){
itList++;
}
if (itList==(*it).second.end()) llista.push_back(dir);
else {
cout << llista.size() << endl;
llista.insert(itList,dir);//->>>>>>>>>>>>>>>>>>>> IT DOESN'T INSERT, WHY?
cout << llista.size() << endl;
}
it->second=llista;
}
else {
llista.push_back(dir);
_mapDirectors.insert(make_pair(director,llista));
}
directorMovies(director);
}
最佳答案
你的 itList
迭代器指的是不同的容器。 itList
指向 _mapDirectors[director].second
的成员但您正试图将其用作 llista
的插入点.
我认为问题是你想要 llista
成为对映射列表的引用,但您正在制作它的拷贝。
试试下面的代码(我没有测试过,但它应该能让你明白)。请注意,它需要一个对映射列表的引用。也无需测试空 map ,或执行显式 find
对于导演 - 你可以简单地引用 _mapDirectors[director].second
如果 map 中不存在空列表,则会自动创建空列表。
void Movies::afegirPeliculaDirector(string director,string title,int year)
{
// get a reference to the director's list
list<actorDirectorMovie>& llista = _mapDirectors[director];
actorDirectorMovie dir(title,year);
list<actorDirectorMovie>::iterator itList=llista.begin();
while(itList!=llista.end() and (*itList) < dir){
itList++;
}
if (itList==llista.end()) llista.push_back(dir);
else {
cout << llista.size() << endl;
llista.insert(itList,dir);
cout << llista.size() << endl;
}
}
您还可以考虑从使用 list
更改为将每位导演的电影存储到 set
,因为它具有自动为您排序的属性。整个函数将缩减为 _mapDirectors[director].insert(dir)
在那种情况下。
关于c++ - 列表插入STL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33813258/