List双向链表容器

来源:互联网 发布:mac播放器下好后怎么 编辑:程序博客网 时间:2024/04/29 20:18
1、

List双向链表容器创建list对象

//创建空链表或者具有n个元素的链表#include<iostream>#include<string.h>#include<stdio.h>#include<ctype.h>#include<algorithm>#include<stack>#include<queue>#include<set>#include<math.h>#include<vector>#include<map>#include<deque>#include<list>using namespace std;int main(){list<int> l;list<int> ll;return 0;}


 

2、

list双向链表容器元素的插入与遍历

//使用push_back()在尾部插入新元素或push_front()在首部插入新元素 链//表都自动扩张;使用insert()在迭代器位置插入元素 链表自动扩张 此时迭代//器只能“++”“--” 不能+n  -n 因为元素位置不是物理相连的#include<iostream>#include<string.h>#include<stdio.h>#include<ctype.h>#include<algorithm>#include<stack>#include<queue>#include<set>#include<math.h>#include<vector>#include<map>#include<deque>#include<list>using namespace std;int main(){    list<int> l;    l.push_back(2);    l.push_back(1);    l.push_back(5);    l.push_front(8);    list<int>::iterator it;    it=l.begin();    it++;    l.insert(it,20);    for(it=l.begin(); it!=l.end(); it++)    {        cout<<*it<<" ";    }    cout<<endl;    return 0;}


 

3、

list双向链表容器元素的反向遍历

//使用reverse_iterator对链表进行反向遍历#include<iostream>#include<string.h>#include<stdio.h>#include<ctype.h>#include<algorithm>#include<stack>#include<queue>#include<set>#include<math.h>#include<vector>#include<map>#include<deque>#include<list>using namespace std;int main(){    list<int> l;    l.push_back(2);    l.push_back(1);    l.push_back(5);    l.push_front(8);    list<int>::iterator it;    it=l.begin();    it++;    l.insert(it,20);    for(it=l.begin(); it!=l.end(); it++)    {        cout<<*it<<" ";    }    cout<<endl;    list<int>::reverse_iterator rit;    for(rit=l.rbegin(); rit!=l.rend(); rit++)    {        cout<<*rit<<" ";    }    cout<<endl;    return 0;}


4、

list双向链表容器元素的删除

//使用remove()删除链表中的一个元素 值相同的元素都会被删除#include<iostream>#include<string.h>#include<stdio.h>#include<ctype.h>#include<algorithm>#include<stack>#include<queue>#include<set>#include<math.h>#include<vector>#include<map>#include<deque>#include<list>using namespace std;int main(){    list<int> l;    l.push_back(2);    l.push_back(1);    l.push_back(2);    l.push_front(8);    list<int>::iterator it;    it=l.begin();    it++;    l.insert(it,20);    for(it=l.begin(); it!=l.end(); it++)    {        cout<<*it<<" ";    }    cout<<endl;    l.remove(2);    for(it=l.begin(); it!=l.end(); it++)    {        cout<<*it<<" ";    }    cout<<endl;    return 0;}


 

//使用pop_front()删除链表首元素,使用pop_back()删除尾元素#include<iostream>#include<string.h>#include<stdio.h>#include<ctype.h>#include<algorithm>#include<stack>#include<queue>#include<set>#include<math.h>#include<vector>#include<map>#include<deque>#include<list>using namespace std;int main(){    list<int> l;    l.push_back(2);    l.push_back(1);    l.push_back(2);    l.push_front(8);    list<int>::iterator it;    it=l.begin();    it++;    l.insert(it,20);    for(it=l.begin(); it!=l.end(); it++)    {        cout<<*it<<" ";    }    cout<<endl;    l.pop_back();    l.pop_front();    for(it=l.begin(); it!=l.end(); it++)    {        cout<<*it<<" ";    }    cout<<endl;    return 0;}


 

//使用erase()删除迭代器位置上的元素#include<iostream>#include<string.h>#include<stdio.h>#include<ctype.h>#include<algorithm>#include<stack>#include<queue>#include<set>#include<math.h>#include<vector>#include<map>#include<deque>#include<list>using namespace std;int main(){    list<int> l;    l.push_back(2);    l.push_back(1);    l.push_back(2);    l.push_front(8);    list<int>::iterator it;    it=l.begin();    it++;    l.insert(it,20);    for(it=l.begin(); it!=l.end(); it++)    {        cout<<*it<<" ";    }    cout<<endl;    it=l.begin();    it++;    it++;    l.erase(it);    for(it=l.begin(); it!=l.end(); it++)    {        cout<<*it<<" ";    }    cout<<endl;    return 0;}


 

//使用clear()清空链表#include<iostream>#include<string.h>#include<stdio.h>#include<ctype.h>#include<algorithm>#include<stack>#include<queue>#include<set>#include<math.h>#include<vector>#include<map>#include<deque>#include<list>using namespace std;int main(){    list<int> l;    l.push_back(2);    l.push_back(1);    l.push_back(2);    l.push_front(8);    list<int>::iterator it;    it=l.begin();    it++;    l.insert(it,20);    for(it=l.begin(); it!=l.end(); it++)    {        cout<<*it<<" ";    }    cout<<endl;    l.clear();    cout<<l.size()<<endl;    return 0;}


5、

list双向链表容器元素的查找

//使用find()查找 如找到返回该元素的迭代器位置 否则 返回end() #include “algorithm”#include<iostream>#include<string.h>#include<stdio.h>#include<ctype.h>#include<algorithm>#include<stack>#include<queue>#include<set>#include<math.h>#include<vector>#include<map>#include<deque>#include<list>using namespace std;int main(){    list<int> l;    l.push_back(2);    l.push_back(1);    l.push_back(2);    l.push_front(8);    list<int>::iterator it;    it=l.begin();    it++;    l.insert(it,20);    for(it=l.begin(); it!=l.end(); it++)    {        cout<<*it<<" ";    }    cout<<endl;    it=find(l.begin(),l.end(),2);    if(it!=l.end()) cout<<*it<<endl;    else cout<<"not find it!"<<endl;    it=find(l.begin(),l.end(),10);    if(it!=l.end()) cout<<*it<<endl;    else cout<<"not find it!"<<endl;    return 0;}


 

6、

 

list双向链表容器元素的排序

//使用sort()对链表元素进行升序排列#include<iostream>#include<string.h>#include<stdio.h>#include<ctype.h>#include<algorithm>#include<stack>#include<queue>#include<set>#include<math.h>#include<vector>#include<map>#include<deque>#include<list>using namespace std;int main(){    list<int> l;    l.push_back(2);    l.push_back(1);    l.push_back(2);    l.push_front(8);    list<int>::iterator it;    it=l.begin();    it++;    l.insert(it,20);    for(it=l.begin(); it!=l.end(); it++)    {        cout<<*it<<" ";    }    cout<<endl;    l.sort();    for(it=l.begin(); it!=l.end(); it++)    {        cout<<*it<<" ";    }    cout<<endl;    return 0;}


 

7、

 

list双向链表容器剔除连续重复的元素

//使用unique()方法剔除连续重复元素 只留下一个#include<iostream>#include<string.h>#include<stdio.h>#include<ctype.h>#include<algorithm>#include<stack>#include<queue>#include<set>#include<math.h>#include<vector>#include<map>#include<deque>#include<list>using namespace std;int main(){    list<int> l;    l.push_back(2);    l.push_back(2);    l.push_back(1);    l.push_back(2);    l.push_front(8);    list<int>::iterator it;    it=l.begin();    it++;    l.insert(it,20);    for(it=l.begin(); it!=l.end(); it++)    {        cout<<*it<<" ";    }    cout<<endl;    l.unique();    for(it=l.begin(); it!=l.end(); it++)    {        cout<<*it<<" ";    }    cout<<endl;    return 0;}


 

 

原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 小米note充电充不进去电怎么办 乐视手机otg功能用不了怎么办 小米4c手机玩王者荣耀卡怎么办 捡的小米6被锁了怎么办 小米5s手机玩穿越火线卡怎么办 苹果平板更新完系统登录不上怎么办 谷歌商店一直卡在核对信息怎么办 贴吧邮箱忘了无法登陆怎么办 华为手机绑定了账号忘了怎么办 淘宝的手机多次注册无法登录怎么办 电脑看不到U盘里面的文件怎么办 c盘访问权限被锁了怎么办 xp系统电脑开机密码忘记了怎么办 华为荣耀9用久了卡怎么办 华为p9相机模糊敲打就正常怎么办 华为p9蓝频按什么都没反映怎么办 华为手机p9开机密码忘了怎么办 华为P9手机开机一直闪屏怎么办 荣耀畅玩7x用户数据锁定怎么办 华为手机p9的指纹解锁坏了怎么办 华为P9青春版外放音量小怎么办 华为麦芒5的开关键失灵怎么办 小米手机进水黑屏但是有声音怎么办 小米5手机突然黑屏没电怎么办 小米4开不了机怎么办充电没反应 小米手机充电没反应开不了机怎么办 红米note手机开不了机怎么办 红米手机突然黑屏开不了机怎么办 红米2a开不开机怎么办 红米4手开不了机怎么办 红米4a开不了机怎么办 魅族手机拨打电话时黑屏怎么办 金立手机拨打电话时黑屏怎么办 红米手机刷机黑屏了怎么办 酷派手机开机黑屏但能嗡嗡响怎么办 酷派手机忘记锁屏密码怎么办 酷派手机锁屏密码忘了怎么办 酷派手机不停的开机关机怎么办 苹果6手机进水了开不了机怎么办 金立手机突然黑屏开不了机怎么办 丢失手机又忘了ID锁怎么办?