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;

}

相关推荐
大白的编程日记.1 小时前
【计算机基础理论知识】C++篇(二)
开发语言·c++·学习
网小鱼的学习笔记1 小时前
python中MongoDB操作实践:查询文档、批量插入文档、更新文档、删除文档
开发语言·python·mongodb
C语言小火车1 小时前
野指针:C/C++内存管理的“幽灵陷阱”与系统化规避策略
c语言·c++·学习·指针
Q_Q5110082851 小时前
python的保险业务管理与数据分析系统
开发语言·spring boot·python·django·flask·node.js·php
亮1111 小时前
Maven 编译过程中发生了 Java Heap Space 内存溢出(OutOfMemoryError)
java·开发语言·maven
凤年徐1 小时前
【数据结构】时间复杂度和空间复杂度
c语言·数据结构·c++·笔记·算法
Chef_Chen1 小时前
从0开始学习R语言--Day40--Kruskal-Wallis检验
开发语言·学习·r语言
Zhu_S W2 小时前
深入理解Java虚拟机:Java内存区域与内存溢出异常
java·开发语言·jvm
灰海2 小时前
原型与原型链到底是什么?
开发语言·前端·javascript·es6·原型模式·原生js
踏莎行hyx2 小时前
使用langchain连接llama.cpp部署的本地deepseek大模型开发简单的LLM应用
c++·ai·langchain·大模型·llama.cpp·deepseek