14-6-3C++的list

(一)list的插入

1.list.insert(pos,elem);//在pos位置插入一个elem元素的拷贝,返回新数据的位置

#include <iostream>

#include <list>

using namespace std;

int main()

{

list<int> lst;

lst.push_back(10);

lst.push_back(30);

lst.push_back(40);

list<int>::iterator it;

it=lst.begin() ;

it++;

lst.insert(it,20);

for(it=lst.begin();it!=lst.end();it++)

{

cout<<*it<<" ";

}

cout<<endl;

return 0;

}

#include <iostream>

#include <list>

using namespace std;

int main()

{

list<int> lst;

lst.push_back(10);

lst.push_back(30);

lst.push_back(50);

list<int>::iterator it;

for(it=lst.begin();it!=lst.end();it++)

{

if(*it==50)

break;

}

if(it!=lst.end())

{

lst.insert(it,40);

}

for(it=lst.begin();it!=lst.end();it++)

{

cout<<*it<<" ";

}

cout<<endl;

return 0;

}

2.list.insert(pos,n,elem);//在pos位置插入n个elem数据,无返回值

#include <iostream>

#include <list>

using namespace std;

int main()

{

list<int> lst;

lst.push_back(10);

lst.push_back(30);

lst.push_back(50);

list<int>::iterator it = lst.end();

lst.insert(it, 3, 70);

for(it = lst.begin(); it != lst.end(); ++it)

{

cout << *it << " ";

}

cout << endl;

return 0;

}

3.list.insert(pos,beg,end);//在pos位置插入[beg,end)区间的数据,无返回值

#include <iostream>

#include <list>

using namespace std;

int main()

{

list<int> lst, lst1;

lst.push_back(10);

lst.push_back(30);

lst.push_back(50);

lst1.push_back(20);

lst1.push_back(40);

list<int>::iterator it;

for(it = lst.begin(); it != lst.end(); ++it)

{

cout << *it << " ";

}

cout << endl;

lst.insert(lst.end(), lst1.begin(), lst1.end());

for(it = lst.begin(); it != lst.end(); ++it)

{

cout << *it << " ";

}

cout << endl;

return 0;

}


(二)list的删除

1.list.clear(); //移除容器的所有数据

#include <iostream>

#include <list>

using namespace std;

int main()

{

list<int> lst, lst1;

lst.push_back(10);

lst.push_back(30);

lst.push_back(50);

lst.push_back(70);

lst.push_back(90);

lst.push_back(110);

lst.push_back(110);

lst.push_back(110);

list<int>::iterator it;

lst.clear();

cout<<"empty?="<<lst.empty() <<endl;

return 0;

}

2.list.erase(beg,end);//删除[beg,end)区间的数据,返回下一个数据的位置,list.erase(pos);//删除pos位置的数据,返回下一个数据的位置

#include <iostream>

#include <list>

using namespace std;

int main()

{

list<int> lst, lst1;

lst.push_back(10);

lst.push_back(30);

lst.push_back(50);

list<int>::iterator it;

it=lst.begin() ;

it++;

it++;

lst.erase(it);

for(it = lst.begin(); it != lst.end(); ++it)

{

cout << *it << " ";

}

cout << endl;

return 0;

}

3.Ist.remove(elem)://删除容器中所有与elem值匹配的元素

#include <iostream>

#include <list>

using namespace std;

int main()

{

list<int> lst, lst1;

lst.push_back(10);

lst.push_back(30);

lst.push_back(50);

lst.push_back(70);

lst.push_back(90);

lst.push_back(110);

lst.push_back(110);

lst.push_back(110);

list<int>::iterator it;

lst.remove(110);

for(it = lst.begin(); it != lst.end(); ++it)

{

cout << *it << " ";

}

cout << endl;

return 0;

}


(三)list的反转

#include <iostream>

#include <list>

using namespace std;

int main()

{

list<int> lst, lst1;

lst.push_back(10);

lst.push_back(30);

lst.push_back(50);

lst.push_back(70);

lst.push_back(90);

lst.push_back(110);

list<int>::iterator it;

lst.reverse() ;

for(it=lst.begin() ;it!=lst.end() ;it++)

{

cout<<*it<<" ";

}

cout<<endl;

return 0;

}

相关推荐
故事和你9115 分钟前
洛谷-算法2-1-前缀和、差分与离散化1
开发语言·数据结构·c++·算法·深度优先·动态规划·图论
励志的小陈6 小时前
贪吃蛇(C语言实现,API)
c语言·开发语言
Makoto_Kimur6 小时前
java开发面试-AI Coding速成
java·开发语言
laowangpython7 小时前
Gurobi求解器Matlab安装配置教程
开发语言·其他·matlab
wengqidaifeng7 小时前
python启航:1.基础语法知识
开发语言·python
观北海7 小时前
Windows 平台 Python 极简 ORB-SLAM3 Demo,从零实现实时视觉定位
开发语言·python·动态规划
handler018 小时前
从零实现自动化构建:Linux Makefile 完全指南
linux·c++·笔记·学习·自动化
Ulyanov8 小时前
《PySide6 GUI开发指南:QML核心与实践》 第二篇:QML语法精要——构建声明式UI的基础
java·开发语言·javascript·python·ui·gui·雷达电子对抗系统仿真
码界筑梦坊8 小时前
357-基于Java的大型商场应急预案管理系统
java·开发语言·毕业设计·知识分享
anzhxu9 小时前
Go基础之环境搭建
开发语言·后端·golang