Lesson10---list

lesson18:

一、

1.list是一个XX链表(0:19:26)

2.链表里面,单独存储数据最适合的结构是XX(0:19:53)

3.list的任意位置插入删除的时间复杂度是O(N)吗?(0:20:20)

4.为什么list容量相关的接口这么少?(0:23:40)

5.emplace_back的功能和XX一样(0:24:7)

6.emplace_front的功能和XX一样(0:24:13)

7.范围for的底层就是XX(0:26:38)

8.为什么它没有find?(0:33:32)

9.insert(pos,30),插入后pos会失效吗?(0:37:45)

a.为什么?(0:38:20)
b.可以用pos对当前结点的值进行修改吗?(0:39:10)

10.erase(pos),删除后pos会失效吗?(0:42:35)

11.splice的作用(0:45:18)

a.转移所有的元素吗?(0:45:54~0:46:7)
b.举例理解(0:46:30~0:47:18) 

12.remove是删除所有的元素还是留一个元素?(0:48:40)

13.clear的作用(0:51:25)

14.unique的作用(0:52:4)

a.前提(0:52:9)
b.真要去重的话,会用unique吗?(0:53:27)

15.双向链表逆置的话,简单不?(0:54:34)

16.为什么list还要单独创建一个sort接口?(0:57:34)

a.如果我用算法库的sort会发生什么?(0:58:04)
b.链表的sort用的什么排序?
①可以用冒泡排序吗?(1:0:24)
②可以用插入排序吗?(1:0:40)
Ⅰ.单链表可以用插入排序吗?(1:0:50)
③它用的什么排序?(1:1:9)
Ⅰ.这种排序对数组的缺陷是什么?(1:1:34)
Ⅱ.对链表呢?(1:1:50)
c.N个数据需要排序,你会选择vector+算法sort还是list+sort?(1:3:29)
①验证(1:7:37)
②快排和归并的时间复杂度都是O(N*logN),所以它俩的结果几乎一样吗?(1:9:5)
③建议用链表排序吗?(1:10:28)
④list拷贝到vector排序后拷回list和list+vector比较效率(1:12:20)

17.merge的作用(1:13:10)

二、list的模拟实现

1.什么是link_type?(1:31:14)

2.get_node是什么?(1:33:34)

a.list_node_allocator::allocate是什么?(1:33:27)
①内存池申请的结点除了开辟空间外,调用了构造和析构函数吗?(1:33:44)
②如果内存不是来自new,而是来自内存池,我想初始化但是调不了构造函数,有办法让我调用构造函数吗?(1:34:45~1:35:25)
Ⅰ.销毁结点呢?(1:35:51)

三、结点的成员变量(1:37:45)

四、链表的成员变量

1.C++如何typedef结点名?(1:38:5)

2.成员变量里有哨兵卫吗?(1:38:27)

五、链表的构造函数

1.头节点怎么初始化?(1:39:20~1:39:50)

六、push_back

1.需要找到并定义尾结点tail吗?(1:43:25)

2.如何利用结点的构造函数创建新结点?(1:44:28~1:45:10)

a.那我要是不传参x,想让它默认给我生成一个,怎么修改构造函数?(1:45:30)

3.实现(1:46:50)

七、

Lesson10---list_第1张图片

1.能不能像string、vector那样用原生指针遍历链表?

a.node*解引用后是数据吗?(1:51:3)
b.node*++能到下一个结点吗?(1:51:55)
c.如何解决上面两个问题?(1:52:40~1:53:0)

2.建议把两个结点和链表两个类写成内部类吗?(1:54:10)

3.链表的迭代器是怎么typedef得来的?(1:56:15)

4.__list_iterator是什么?(1:56:45)

八、迭代器

1.list类如何使用迭代器?(2:2:8)

2.迭代器需要控制哪些行为?

a.第一个(2:5:30)

b.第二个(2:7:44)
c.第三个(2:9:30)

3.迭代器需要提供析构函数吗?(2:32:38)

九、begin(2:3:45)

十、end(2:3:45)

十一、operator!=

1.可以在__list_iterator类内部typedef吗?(2:5:58)

2.链表的迭代器比较是否相等,怎么比?(2:6:19)

3.it指向_node是用.还是->?(2:11:35)

十二、operator*

1.实现(2:8:20)

2.*it被转换成了XX(2:8:35)

十三、operator++

1.这是前置还是后置++?(2:9:40)

2.++到下一个结点的思路?(2:9:55)

3.实现(2:10:25)

4.这是赋值吗?(2:14:43)

list::iterator it = it.begin();

5.后置++怎么和前置++区分?(2:35:8)

a.实现(2:35:30)
①为什么不写拷贝构造?(2:35:24)

十四、operator--

1.实现(2:35:50)

2.后置--的实现(2:36:10)

十五、

1.指针什么时候才用箭头->?(2:38:38)(2:39:15)

a.->是用来干嘛的?(2:39:18)

2.对于list lt,怎么push_back?(2:41:10)

struct Pos
{
	int _a1;
	int _a2;
	Pos(int a1 = 0; int a2 = 0)
		:_a1(a1)
		, _a2(a2)
	{}
};

3.报错的原因(2:43:20)

Lesson10---list_第2张图片

a.解决方案?(2种)
①第一种(2:43:28)
②第二种(2:43:50)
③第三种(2:46:0)
Ⅰ.直接用it->是会报错的,需要XX(2:46:25)
b.如何实现重载->?(2:50:0)
①&(operator*())等价于XX(2:50:15)
②返回值是返回什么?(2:50:25)
c.严格来说,it->_a1其实等价于XX(2:51:20)
①it->转化成调用XX(2:51:40)
Ⅰ.返回值返回什么?(2:51:52)
Ⅱ.T*是结构体的XX(2:51:59)
Ⅲ.T*再加个XX就可以访问成员了(2:56:2)
②语法为了可读性,做了什么?(2:52:35)

4.如果我使用Func(lt),把对象传给函数去遍历,可以吗?(2:56:43)

Lesson10---list_第3张图片

a.为什么?(2:56:46~2:57:0)
b.怎么办?(2:57:5)
c.普通迭代器和const迭代器真正的区别在于是否可以修改数据,那么通过控制哪里可以起到控制是否能够交换数据?(2:59:0)
①返回值不同,可以构成重载吗?(2:59:41)
d.怎么解决?(2种)
①第一种(2:59:51~3:0:10)
②第二种(3:0:20~3:3:5)

5.怎么修改迭代器的typedef?(3:4:0)(3:5:27)

a.普通迭代器的begin和const迭代器的begin的区别?(3:4:31)

十六、insert

1.实现(3:12:15)

2.push_back怎么复用insert?(3:14:8)

十七、push_front

1.实现(3:14:35)

十八、erase

1.assert警告什么?(3:15:38)

2.实现(3:17:15)

十九、pop_back

1.实现(3:17:55)

二十、pop_front

1.实现(3:18:20)

二十一、find

1.为什么使用find函数前,要加一堆typedef?(3:23:40)

lesson19:

一、拷贝构造

1.编译器默认生成的拷贝构造是XX拷贝(0:3:32)

a.lt存的是什么?(0:3:54)
vector lt;
b.浅拷贝拷的啥?(0:4:8)
c.a、b问题的可视化(0:4:45)

Lesson10---list_第4张图片

d.编译器默认生成的拷贝构造对内置类型XX,对自定义类型XX(0:5:13)
e.为什么没有崩溃?(0:7:58)
f.修改会导致崩溃吗?(0:9:22)

二、clear

1.clear和析构的区别(0:11:19)

2.删除节点的时候,除了用delete外,还有XX(0:12:34)

a.erase以后,节点所在的迭代器就失效了,怎么由该节点指向下一个节点?(0:12:55)

三、析构函数

1.实现(0:15:10)

四、拷贝构造

1.传统写法

a.思路(0:17:55)

2.现代写法

a.思路(0:18:13)
b.它只能传链表的迭代器区间来构造吗?(0:19:14)

Lesson10---list_第5张图片

①实现(0:22:0)
Ⅰ.push_back的前提(0:20:20)
Ⅱ.empty_init函数的实现(0:22:5)
Ⅲ.empty_init的作用(0:22:25)
c.实现(0:25:0)
①为什么都交换了,还要在交换前对this对象初始化?(0:31:44)

五、swap函数

1.链表的swap是在交换什么?(0:25:34)

2.实现(0:25:35)

六、operator=

1.实现(0:33:40)

七、

list lt;

1.可以这样写吗?(0:36:27)

2.类名是类型吗?(0:36:37)

3.什么是类型?(0:36:40)

4.在哪里的时候,类名可以当成是类型?(2处)

a.第一处(0:37:3)
b.第二处(0:37:19)

你可能感兴趣的:(排序算法,算法)