list和vector都可以使用erase函数移除指定下标的元素,注意输入的是迭代器,返回值为指向下一个元素的位置。:
iterator erase(iterator position);
iterator erase(iterator first,iterator last);
如果下标是index,直接调用即可:
list.erase(list.begin() + index);
如果根据下标一次性删除多个元素,则会发生错误,因为删除一个元素后,元素个数会发生变化,因此下标就会出现错误,正确代码如下:
#include <vector>
#include <list>
#include <iostream>
using namespace std;
bool sort_desc(int a, int b)
{
return a > b;
}
int main(int argc, char *argv[])
{
list<int> mylist;
mylist.push_back(5);
mylist.push_back(8);
mylist.push_back(9);
mylist.push_back(2);
mylist.push_back(4);
mylist.push_back(6);
list<int> index;
index.push_back(1);
index.push_back(3);
index.push_back(4);
index.sort(sort_desc);//对下标数组进行降序
for(list<int>::iterator iter=index.begin(); iter!=index.end(); iter++)
{
list<int>::iterator delIter=mylist.begin();
advance(delIter, *iter);//按照由大到小的下标顺序进行删除元素,这样被删除元素的下标是永远不会变的
mylist.erase(delIter);
}
for(list<int>::iterator iter=mylist.begin(); iter!=mylist.end(); iter++)
{
cout << *iter << " ";
}
cout << endl;
return 0;
}