学习链表的笔记

关于小白学习List的点滴笔记(B站黑马学视频总结)

在这里插入图片描述
STL中的链表是一个双向循环链表
在这里插入图片描述
list的优点:
采用动态存储分配,不会造成内存浪费和溢出
链表执行插入和删除操作十分方便,修改指针即可,不需要移动大量元素
list的缺点:
链表灵活,但是空间(指针域) 和 时间(遍历)额外耗费较大
List有一个重要的性质,插入操作和删除操作都不会造成原有list迭代器的失效,这在vector是不成立的。

1.1 链表的构建

示例:

    //创建list容器
    
    //默认构造
	list<int>L1;
	
    //区间的方式来构造
	list<int>L2(L1.begin(), L1.end());
	
	//拷贝构造
	list<int>L3(L2);
	
	//n个elem
	list<int>L4(5, 6);

    //给list容器中添加数据,这里利用的是尾插法
	L1.push_back(10);
	L1.push_back(20);
	L1.push_back(30);
	L1.push_back(40);

1.2赋值

示例:

//下面是list的赋值的四种方法
//1、这里前面已经介绍
	list<int>p1;
	p1.push_back(1);
	p1.push_back(2);
	p1.push_back(4);
	p1.push_back(5);
	p1.push_back(6);
	//2、利用已经创建好的list直接赋值
	list<int>p2;
	p2 = p1;
	
	//3、利用创建好的list的[begin,end]区间的数据拷贝赋值
	list<int>p3;
	p3.assign(p2.begin(), p2.end());
	
	//4、利用n个相同数据拷贝赋值
	list<int>p4;
	p4.assign(3, 42);
	list<int>p5;
	p5.assign(3, 99);
	
	//5、交换两个list的数据
	p5.swap(p4);

1.3 链表的大小操作

方法

//返回容器元素的个数
cout << "L1的元素个数为:" << L1.size() << endl;
//判断容器是否为空
if (L1.empty())
//重新指定容器的长度为num,若容器变长,则以默认值填充新位置。
resize(num, elem);
//如果容器变短,则末尾超出容器长度的元素被删除。
L1.resize(1);
//重新指定容器的长度为num,若容器变长,则以1值填充新位置.
L1.resize(10,1)
//如果容器变短,则末尾超出容器长度的元素被删除。

1.4 删除

方法:

	pop_front();//从容器开头移除第一个元素
	pop_back();//删除容器中最后一个元素
	clear();//移除容器的所有数据
	erase(beg,end);//删除[beg,end)区间的数据,返回下一个数据的位置。
	erase(pos);//删除pos位置的数据,返回下一个数据的位置。
	remove(elem);//删除容器中所有与elem值匹配的元素。
	//删除一个元素或一个区域的元素(两个重载)
	l1.erase(l1.begin()); 将l1的第一个元素删除。
	l1.erase(l1.begin(),l1.end()); 将l1的从begin()到end()之间的元素删除。

示例:

//删除头部一个元素
	L1.pop_front();
	printList(L1);
	//删除尾部一个元素
	L1.pop_back();
	printList(L1);
	//删除容器所有数据
	L1.clear();
	printList(L1);

	//移除容器中所有与elem值匹配的元素,不需要使用迭代器
	L2.remove(3);
	printList(L2);

	//删除第一个元素或一个区域的元素(两个重载),需要使用迭代器
	L2.erase(L2.begin());//删除第一个元素
	printList(L2);
	L2.erase(L2.begin(),L2.end());//删除一个区域的元素
	printList(L2);

1.5 插入

方法:

	push_front(elem);//在容器开头插入一个元素
	push_back(elem);//在容器尾部加入一个元素
	insert(pos,elem);//在pos位置插elem元素的拷贝,返回新数据的位置。
	insert(pos,n,elem);//在pos位置插入n个elem数据,无返回值。
	insert(pos,beg,end);//在pos位置插入[beg,end)区间的数据,无返回值。

示例:

//list的插入
	list<int>L3;
	L3.push_front(9);//头插
	L3.push_front(8);
	L3.push_front(7);
	L3.push_front(6);
	//使用迭代器头部插入
	L3.insert(L3.begin(),100);
	printList(L3);
	//自己准备一个迭代器
	list<int>::const_iterator it = L3.begin();
	//这时候可以移动一个位置然后插入
	L3.insert(++it,1000);//
	printList(L3);

1.6 输出

示例:

	printList(L1);//只读
	void printList(const list<int>& L)
	{
		for (list<int>::const_iterator it = L.begin(); it != L.end(); it++)
		{
			cout << *it << " ";
		}
		cout << endl;
	}
	front(); //返回第一个元素。
	cout << "第一个元素为:" << L1.front() << endl;//返回第一个数据
	back(); //返回最后一个元素
	cout << "最后一个元素为:" << L1.back() << endl;//返回最后一个数据

1.7 排序

方法:

	sort(); //链表排序
	L.sort(myCompare); //指定规则,从大到小
	bool myCompare(int val1 , int val2)
	{
  		return val1 > val2;
  	}
  	//对于自定义数据类型,必须要指定排序规则,否则编译器不知道如何进行排序
  	//高级排序只是在排序规则上再进行一次逻辑规则制定,并不复杂
  	bool comparePerson(Person& p1, Person& p2)
	{
		//年龄进行升序
		if (p1.m_Age == p2.m_Age)
		{
			return p1.m_Height > p2.m_Height;
		}
		else
		return p1.m_Age < p2.m_Age;
	}
	//反转链表
  	reverse(); 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值