c基础——list

文章目录

  • 一、对list的理解
  • 二、使用注意事项
  • 三、几种常用的函数及其使用
  • 总结



提示:以下是本篇文章正文内容,下面案例可供参考

一、对list的理解

若是你学过链表之后 其实简单来说就是就是一个带头节点的双向循环链表,每一个阶段存储着前面一个结点的指针 也存放下一个节点的指针

#define Posi(T) ListNode<T>*
struct ListNode{
	T data;//数值
	Posi(T) pred;//前驱
	Posi(T) succ;//后继
}; 

与上文的容器来对比的话就是,由于是链表的形式,所以更适合插入,并且插入的时候,不会像容器一样,移动数据,指针位置是不变的,所以有大量插入操作的时候优先选择链表

二、使用注意事项

  1. 由于是一种双向循环链表,也就意味着数据的存放并不是连续的,
    所以也就不支持,list.begin()+size这种操作,只能通过迭代器++, --来缓慢移动

  2. begin与end是正向迭代器,对迭代器执行++操作,迭代器向后移动,rbegin与dend是反向迭代器,对迭代器执行++操作迭代器向前移动

三、几种常用的函数及其使用

1、iterator操作函数

常见函数 函数功能
list< int> vec 创建list对象
list< int>::iterator it 使用迭代器来访问元素
常用成员函数 功能
list.begin() 返回指向列表中第一个元素的迭代器。
list.end() 返回指向列表中最后一个元素后一个位置的迭代器。
list.rbegin() 返回指向最后一个元素的反向双向迭代器。
list.rend() 返回指向第一个元素所在位置前一个位置的迭代器。
|l.begin() | 返回指向容器中第一个元素的迭代器 |
|l.end()|返回指向容器的最后一个元素的位置后一个位置的迭代器|
l.rbegin()|返回指向最后一个元素的迭代器
l.rend()|返回指向第一个元素所在位置前一个位置的迭代器
*/
#include
using namespace std;
#define F(i,m,n) for(int i=m;i l){
	cout<<"此时列表中的元素是:" ;
	for(list::iterator it=l.begin();it!=l.end();it++){
		cout<<*it<<",";
	}
	cout< l){
	list::iterator it=l.begin(); 
	printf("第一个迭代器的位置是%p\n",it);
	printf("第一个迭代器的位置是上的数是%d\n",*it);
	Display(l);
} 
void IEnd(list l){
	list::iterator it=l.end(); 
	printf("最后一个迭代器的后一个位置是%p\n",it);
	printf("所以他的前面一个数是最后一个元素%d\n",*(--it)); 
	Display(l);
}
void IRFirst(list l){
	list::reverse_iterator it=l.rbegin(); 
	cout<<"倒数第一个迭代器的位置是上的数是"<<*it< l){
	list::reverse_iterator it=l.rend(); 
	cout<<"所以他的下一个元素是第一个元素是"<<*(--it)< l(a,a+5);
	while(1){
		menu();
		cin>>choice;
		if(5==choice) break;
		switch(choice){
			case 1:{IFirst(l);break;}
			case 2:{IEnd(l);break;}
			case 3:{IRFirst(l);break;}
			case 4:{IREnd(l);break;}
			default:{break;}
		}
	} 	 
	return 0;
}

c基础——list_第1张图片
介于作者的水平,同样的我也遇到了一个问题为什么地址是不一样的 既然是双向循环链表 其中最后一个迭代器的后一个位置,应该是第一个位置呀,此时的地址应该相同才对,

2、容量函数

常用函数 函数功能
list.empty() 判断容器中是否有元素,若无元素,则返回 true;反之,返回 false。
size() 返回当前容器实际包含的元素个数。
max_size 返回可容纳的最大元素数
/*
vec.size()|返回实际元素的个数
vec.empty()|判断当前是否有元素,若无元素返回true,否则则返回false

*/
#include
#include
using namespace std;
#define F(i,m,n) for(int i=m;i<n;i++)//定义一种左闭右开的形式 
int choice,size;int flag=1;list<int> l; char c; 
/*********************功能实现函数*******************************/ 
void Display(){
	cout<<"此时的队列中的元素是"; 
	for(list<int>::iterator it=l.begin();it!=l.end();it++)
	 	cout<<*it<<",";
	cout<<endl;
}
void Size(){
	cout<<"此时的size是"<<l.size()<<endl; 
	Display();
} 
void Empty(){
	cout<<"此时的容器是否为空"<<l.empty()<<endl;
	Display();
}
/***********************操作函数*************************/ 
void menu(){
	cout<<"1、查看实际元素的大小"<<endl; 
	cout<<"2、查看当前是否有元素"<<endl; 
	cout<<"3、退出"<<endl;
}
void Judge(){
		int a[100];int i=0;
		cout<<"是否增加容器中的变量"<<endl;
		cout<<"1、增加 2、不增加";
		cin>>flag; 
		if(1==flag)
		{	
			cout<<"请增加容器中的变量"<<endl;
			getchar(); 
			while(scanf("%d",&a[++i])!=EOF) l.push_back(a[i]);
		}
}
int main(){
	while(1){
		menu();
		cin>>choice;
		if(3==choice) break;
		Judge();
		switch(choice){
			case 1:{Size(); break;}
			case 2:{Empty();break;}
			default:{break;}
		}
	} 	 
	return 0;
}

c基础——list_第2张图片
c基础——list_第3张图片

ps:因为没有容器容器的概念了,所以相较于上面一篇文中,少了一些对caoacity的操作

3、元素访问(可修改)

常用函数 函数功能
front() 返回第一个元素的引用。
back() 返回最后一个元素的引用。
/*
vec.front()|返回第一个元素的引用
vec.back|返回最后一个元素的引用
*/
#include
#include
using namespace std;
#define F(i,m,n) for(int i=m;i<n;i++)//定义一种左闭右开的形式 
int choice,size,val;int flag=1;list<int> l; char c; 
/*********************功能实现函数*******************************/ 
void Display(){
	cout<<"此时的队列中的元素是"; 
	for(list<int>::iterator it=l.begin();it!=l.end();it++)
	 	cout<<*it<<",";
	cout<<endl;
}
int Front(){
	cout<<"第一个元素的引用是"<<l.front()<<endl; 
	cout<<"你想修改成什么"<<endl; 
	cin>>val;l.front()=val;
	cout<<"此时第一个元素的值是"<<l.front()<<endl; 
	Display();
} 
int Back(){
	cout<<"最后一个元素的引用是"<<l.back()<<endl; 
	cout<<"你想修改成什么"<<endl; 
	cin>>val;l.back()=val;
	cout<<"此时最后一个元素的值是"<<l.back()<<endl; 
	Display();	
}
/***********************操作函数*************************/ 
void menu(){
	cout<<"1、返回第一个元素的引用" <<endl;
	cout<<"2、返回最后一个函数的引用"<<endl;
	cout<<"3、展示当前列表"<<endl; 
	cout<<"4、退出"<<endl;
}
void Judge(){
		int a[100];int i=0;
		cout<<"是否增加列表中的变量"<<endl;
		cout<<"1、增加 2、不增加"<<endl;;
		cin>>flag; 
		if(1==flag)
		{	
			cout<<"请增加列表中的变量"<<endl;
			getchar(); 
			while(scanf("%d",&a[++i])!=EOF) l.push_back(a[i]);
		}
}
int main(){
	while(1){
		menu();
		cin>>choice;
		if(4==choice) break;
		Judge();
		switch(choice){
			case 1:{Front();break;}
			case 2:{Back();break;}
			case 3:{Display();break;}
			default:{break;}
		}
	} 	 
	return 0;
}

c基础——list_第4张图片

4、更行(修改)操作

常用函数 函数功能
assign() 用新元素替换容器中原有内容。
emplace_front() 在容器头部生成一个元素。该函数和 push_front() 的功能相同,但效率更高。
push_front() 在容器头部插入一个元素。
pop_front() 删除容器头部的一个元素。
emplace_back() 在容器尾部直接生成一个元素。该函数和 push_back() 的功能相同,但效率更高。
push_back() 在容器尾部插入一个元素。
pop_back() 删除容器尾部的一个元素。
pop() 通过指定索来删除元素,若是没有索引默认输出最后一个元素,返回值,删除的元素
emplace() 在容器中的指定位置插入元素。该函数和 insert() 功能相同,但效率更高。
insert() 在容器中的指定位置插入元素。
erase() 删除容器中一个或某区域内的元素。
swap() 交换两个容器中的元素,必须保证这两个容器中存储的元素类型是相同的。
clear() 删除容器存储的所有元素,返回值为空列表。
remove(val) 删除容器中值等于 val 没有返回值。
remove_if() 删除容器中满足条件的元素。但是并没有真正移除 而是返回满足条件 的指针,所以很多时候配合earse与有序list来用
unique() 删除容器中相邻的重复元素,只保留一个。
/*vec.assign()|使用新元素来代替原有的内容
vec.push_back(a)|在序列的末尾添加一个元素
vec.pop_back()|移除序列尾部的元素
vec.insert(vec.begin()+i,a)|在指定位置插入一个或者多个元素
vec.erase(vec.begin()+2)/vec.rease(vec.begin()+i,vec.begin()+j)|移除第三个元素/移除第[i,j)
vec.clear()|移除所有元素 列表大小变为零
swap()|交换两个列表的所有元素
emplace()|在指定位置直接生成一个元素
emplace_back()|在序列尾部生成一个元素 
与上一个容器的区别在于,不能直接加上数字,来进行区间的跳转 
*/
#include
#include
using namespace std;
#define F(i,m,n) for(int i=m;i<n;i++)//定义一种左闭右开的形式 
int choice,size,val;int flag=1;list<int> l; char c; 
list<int>::iterator it,BeginIt=l.begin(),EndIt=l.begin(); //后面这两个用来做区间 
/*需要定义两个迭代器,来确定区间,*/ 
/*********************功能实现函数*******************************/ 
void Display(){
	cout<<"此时的队列中的元素是"; 
	for(list<int>::iterator it=l.begin();it!=l.end();it++)
	 	cout<<*it<<",";
	cout<<endl;
}
void Assign(){ //;三种方式 一种是替换元素保留个数,一种是 使用迭代器来确定区间  只有这区间的数被保留 
	int beg,end; 
	cout<<"请选择方式"<<endl;
	cout<<"1、一种是替换元素保留个数"<<endl;
	cout<<"2、使用迭代器来确定区间" <<endl;
	cin>>flag;
	if(1==flag){
		cout<<"请输入你想替换的元素"<<endl; 
		cin>>val; 
		cout<<"请输入你还想留几个元素"<<endl; 
		cin>>size;
		l.assign(size,val);
	}
	else{
		cout<<"请输入你想替换的区间";
		cin>>beg>>end;it=l.begin();
		while(beg--) BeginIt++;
		while(end--) EndIt++;
		l.assign(BeginIt,EndIt);  
	}
	Display();		
} 
void Push_back(){
	cout<<"请输入你要添加的值"<<endl;
	cin>>val;
	l.push_back(val);
	Display(); 
}
void Pop_back(){
	cout<<"将会弹出列表最后一个元素";
	l.pop_back();
	Display(); 
}
void Insert(){
	int beg;int n;int val;
	cout<<"请输入你要的位置(size)之前以及n个val"<<endl;
		cin>>beg>>n>>val;
		while(beg--) BeginIt++;
	l.insert(BeginIt,n,val);
	Display();
}
void Erase(){//移除某一个区间或者某一个确定位置的元素
	int beg,end; 
	cout<<"请输入你想去除的区间(1)或位置(2)"<<endl;
	cin>>flag; 
		if(1==flag){
			cin>>beg>>end;
			while(beg--){BeginIt++;};
			while(end--){EndIt++;};
			l.erase(BeginIt,EndIt);
			}
		else{
			cout<<"请输入一个位置";
			cin>>size;
			//l.pop(size);提示没有pop函数,我没有实现 
		}
		Display();
}
void Clear(){//移除所有的元素,容量清零
	int beg;int end1;
	cout<<"请问你要删除什么类型的元素"<<endl;
	cout<<"1、清除值为val的元素"<<endl;
	cout<<"2、删除容器中相邻的重复元素"<<endl; 
	cout<<"3、清除所有的元素"<<endl; 
	cin>>choice;
	switch(choice){
		case 1:{
			cout<<"请输入你要删除的值(val)"<<endl;
			cin>>val;
			printf("%d",val);
			l.remove(val);Display();
			break;
		}
		case 2:{
			cout<<"删除重复值之后"<<endl;
			l.unique();
			Display();
			break;
		}
		case 3:{
			cout<<"清除所有的元素"<<endl;
			l.clear(); Display();
			break;
		}
		default:break;
	}
}
void Swap(){//交换两个列表 
	int b[100];int i=0;
	list<int> l1;
	cout<<"请再输入一个列表"<<endl;
	while(scanf("%d",&b[++i])!=EOF) l1.push_back(b[i]);
	swap(l,l1);
}
void Emplace(){//再指定位置生成一个元素
	cout<<"请输出再size位置放入元素val"<<endl;
	cin>>size>>val;
	while(size--){BeginIt++;};
	l.emplace(BeginIt,val);
	Display(); 
}
void Emplace_back(){
	cout<<"请输出一个val"<<endl; 
	cin>>val;
	l.emplace_back(val);
	Display();
}

/***********************操作函数*************************/ 
void menu(){
	cout<<"1、使用新元素来代替原有的内容"<<endl;
	cout<<"2、在序列的末尾添加一个元素"<<endl;
	cout<<"3、移除序列尾部的元素"<<endl;
	cout<<"4、在指定位置插入一个或者多个元素"<<endl;
	cout<<"5、移除某一个区间或者某一位置的元素"<<endl;
	cout<<"6、移除元素(包括某一特定的值,所有)"<<endl;
	cout<<"7、交换两个列表的所有元素"<<endl;
	cout<<"8、在指定位置直接生成一个元素"<<endl;
	cout<<"9、在序列尾部生成一个元素"<<endl;
	cout<<"10、展示当前列表"<<endl; 
	cout<<"11、退出"<<endl;
}
void Judge(){
		int a[100];int i=0;
		cout<<"是否增加列表中的变量"<<endl;
		cout<<"1、增加 2、不增加"<<endl;;
		cin>>flag; 
		if(1==flag)
		{	
			cout<<"请增加列表中的变量"<<endl;
			getchar(); 
			while(scanf("%d",&a[++i])!=EOF) l.push_back(a[i]);
		}
}
int main(){
	while(1){
		menu();
		cin>>choice;
		if(11==choice) break;
		Judge();
		switch(choice){
			case 1:{Assign();break;}
			case 2:{Push_back();break;}
			case 3:{Pop_back();break;}
			case 4:{Insert();break;}
			case 5:{Erase();break;}
			case 6:{Clear();break;}
			case 7:{Swap();break;}
			case 8:{Emplace();break;}
			case 9:{Emplace_back();break;}
			case 10:{Display();break;}
			default:{break;}
		}
	} 	 
	return 0;
}

这个就不发截图了,因为实在是太多,可以自己尝试一下哦
5、操作函数

常用函数 基本功能
merge() 合并两个事先已排好序的 list 容器,并且合并之后的 list 容器依然是有序的。
sort() 通过更改容器中元素的位置,将它们进行排序。
sort(reverse=True) 从小到大排序
reverse() 反转容器中元素的顺序
/*
merge()|合并两个事先已排好序的 list 容器,并且合并之后的 list 容器依然是有序的。
sort()|通过更改容器中元素的位置,将它们进行排序。
sort(reverse=True)|从小到大排序|
reverse()|反转容器中元素的顺序
|count()|统计某个元素出现的次数|
|index|返回某值子啊列表中出现的索引(找不到就报错)|
*/
#include
#include
using namespace std;
#define F(i,m,n) for(int i=m;i<n;i++)//定义一种左闭右开的形式 
int choice,size,val;int flag=1;list<int> l; char c; 
list<int>::iterator it,BeginIt=l.begin(),EndIt=l.begin(); //后面这两个用来做区间 
/*需要定义两个迭代器,来确定区间,*/ 
/*********************功能实现函数*******************************/ 
void Display(){
	cout<<"此时的队列中的元素是"; 
	for(list<int>::iterator it=l.begin();it!=l.end();it++)
	 	cout<<*it<<",";
	cout<<endl;
}
void Merge(){//合并两个有序list 
	list<int> l1;int a[10]={0};int i=0;
	cout<<"请在输出一个序列"<<endl;
	while(scanf("%d",&a[++i])!=EOF) l1.push_back(a[i]);
	l.merge(l1);
	Display();
}
void Sort(){
	cout<<"请问你要用何种方式输出"<<endl;
	cout<<"1、从小到大,2、从大到小"<<endl;
	cin>>flag;
	if(1==flag) {l.sort();};
	else l.sort(reverse=True);
}
void Reverse(){
	l.reverse();
	Display();
}
/***********************操作函数*************************/ 
void menu(){
	cout<<"1、合并两个数组"<<endl;
	cout<<"2、将列表中数字按照从大到小的输出"<<endl;
	cout<<"3、将列表中值反转"<<endl;	
	cout<<"4、展示当前列表"<<endl; 
	cout<<"5、退出"<<endl;
}
void Judge(){
		int a[100];int i=0;
		cout<<"是否增加列表中的变量"<<endl;
		cout<<"1、增加 2、不增加"<<endl;;
		cin>>flag; 
		if(1==flag)
		{	
			cout<<"请增加列表中的变量"<<endl;
			getchar(); 
			while(scanf("%d",&a[++i])!=EOF) l.push_back(a[i]);
		}
}
int main(){
	while(1){
		menu();
		cin>>choice;
		if(11==choice) break;
		Judge();
		switch(choice){
			case 1:{
				Merge();
				break;
			} 
			case 2:{
				Sort();
				break;
			} 
			case 3:{
				Reverse();
				break;
			}
			case 4:{
				Display();
				break;
			} 
			default:break;
		}
	} 	 
	return 0;
}

总结

若是文章对你的提升由哪怕一点帮助的话 请答应我 不要吝啬你的点赞评论 转载请告知哪一部分我检查一下

你可能感兴趣的:(笔记,list,c++,c语言)