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;

}

相关推荐
千里码aicood1 分钟前
[含文档+PPT+源码等]精品基于Python实现的校园小助手小程序的设计与实现
开发语言·前端·python
讨厌下雨的天空1 分钟前
C++之list
开发语言·c++·list
大麦大麦30 分钟前
深入剖析 Sass:从基础到进阶的 CSS 预处理器应用指南
开发语言·前端·css·面试·rust·uni-app·sass
hhw1991121 小时前
c#面试题整理6
java·开发语言·c#
Icomi_1 小时前
【神经网络】0.深度学习基础:解锁深度学习,重塑未来的智能新引擎
c语言·c++·人工智能·python·深度学习·神经网络
蠟筆小新工程師1 小时前
Deepseek可以通过多种方式帮助CAD加速工作
开发语言·python·seepdeek
不知道取啥耶2 小时前
C++ 滑动窗口
数据结构·c++·算法·leetcode
天道有情战天下3 小时前
python flask
开发语言·python·flask
zephyr_zeng3 小时前
VsCode + EIDE + OpenOCD + STM32(野火DAP) 开发环境配置
c语言·c++·vscode·stm32·单片机·嵌入式硬件·编辑器
帅弟1503 小时前
Day4 C语言与画面显示练习
c语言·开发语言