22
33https://leetcode-cn.com/problems/remove-linked-list-elements/ 
44
5- # leetcode:203. 移除链表元素   
5+ >  链表操作中,可以使用原链表来直接进行删除操作,也可以设置一个虚拟头结点在进行删除操作,接下来看一看哪种方式更方便。
6+ 
7+ # 第203题:移除链表元素   
8+ 
69题意:删除链表中等于给定值 val 的所有节点。
7- 示例:
8- 输入: 1->2->6->3->4->5->6, val = 6
9- 输出: 1->2->3->4->5
10+ 
11+ ![ 203题目示例] ( https://img-blog.csdnimg.cn/20200814104441179.png ) 
1012
1113# 思路   
1214
13- 我们这里以链表  1 4 2 4 来举例,移除元素4。
15+ 这里以链表  1 4 2 4 来举例,移除元素4。
1416
1517<img  src =' ../pics/203_链表删除元素1.png '  width =600 > </img ></div >
1618
@@ -20,24 +22,24 @@ https://leetcode-cn.com/problems/remove-linked-list-elements/
2022
2123** 当然如果使用java ,python的话就不用手动管理内存了。** 
2224
23- 还要说明一下,就算我们使用C ++来做leetcode,如果移除一个节点之后,没有手动在内存中删除这个节点,leetcode依然也是可以通过的,只不过,内存使用的空间大一些而已,但建议依然要养生手动清理内存的习惯。
25+ 还要说明一下,就算使用C ++来做leetcode,如果移除一个节点之后,没有手动在内存中删除这个节点,leetcode依然也是可以通过的,只不过,内存使用的空间大一些而已,但建议依然要养生手动清理内存的习惯。
2426
2527这种情况下的移除操作,就是让节点next指针直接指向下下一个节点就可以了, 
2628
27- 那么因为单链表的特殊性,只能指向下一个节点,我们刚刚删除的是链表的中第二个 ,和第四个节点,那么如果我们删除的是头结点又该怎么办呢 ?
29+ 那么因为单链表的特殊性,只能指向下一个节点,刚刚删除的是链表的中第二个 ,和第四个节点,那么如果删除的是头结点又该怎么办呢 ?
2830
2931这里就涉及如下链表操作的两种方式:
3032*  ** 直接使用原来的链表来进行删除操作。**  
3133*  ** 设置一个虚拟头结点在进行删除操作。** 
3234
3335
34- 我们来看第一种操作 :直接使用原来的链表来进行移除。
36+ 来看第一种操作 :直接使用原来的链表来进行移除。
3537
3638<img  src =' ../pics/203_链表删除元素3.png '  width =600 > </img ></div >
3739
3840移除头结点和移除其他节点的操作是不一样的,因为链表的其他节点都是通过前一个节点来移除当前节点,而头结点没有前一个节点。
3941
40- 所以头结点如何移除呢,其实我们只要将头结点向后移动一位就可以,这样我们就从链表中移除了一个头结点 。
42+ 所以头结点如何移除呢,其实只要将头结点向后移动一位就可以,这样就从链表中移除了一个头结点 。
4143
4244<img  src =' ../pics/203_链表删除元素4.png '  width =600 > </img ></div >
4345
@@ -46,21 +48,21 @@ https://leetcode-cn.com/problems/remove-linked-list-elements/
4648<img  src =' ../pics/203_链表删除元素5.png '  width =600 > </img ></div >
4749
4850
49- 这样我们移除了一个头结点 ,是不是发现,在单链表中移除头结点 和 移除其他节点的操作方式是不一样,其实在我们写代码的时候也会发现 ,需要单独写一段逻辑来处理移除头结点的情况。
51+ 这样移除了一个头结点 ,是不是发现,在单链表中移除头结点 和 移除其他节点的操作方式是不一样,其实在写代码的时候也会发现 ,需要单独写一段逻辑来处理移除头结点的情况。
5052
5153那么可不可以 以一种统一的逻辑来移除 链表的节点呢。 
5254
5355其实** 可以设置一个虚拟头结点** ,这样原链表的所有节点就都可以按照统一的方式进行移除了。
5456
55- 我们来看看如何设置一个虚拟头。我们依然还是在这个链表中 ,移除元素1。
57+ 来看看如何设置一个虚拟头。依然还是在这个链表中 ,移除元素1。
5658
5759<img  src =' ../pics/203_链表删除元素6.png '  width =600 > </img ></div >
5860
59- 这里我们来给链表添加一个虚拟头结点为新的头结点,此时我们要移除这个旧头结点元素1 。
61+ 这里来给链表添加一个虚拟头结点为新的头结点,此时要移除这个旧头结点元素1 。
6062
6163这样是不是就可以使用和移除链表其他节点的方式统一了呢?
6264
63- 来看一下,如何移除元素1 呢,还是我们熟悉的方式 ,然后从内存中删除元素1。
65+ 来看一下,如何移除元素1 呢,还是熟悉的方式 ,然后从内存中删除元素1。
6466
6567最后呢在题目中,return 头结点的时候,别忘了 ` return dummyNode->next; ` , 这才是新的头结点
6668
@@ -119,6 +121,7 @@ public:
119121 } 
120122}; 
121123``` 
124+ ** 我将算法学习相关的资料已经整理到了Github上:https://github.com/youngyangyang04/leetcode-master,里面还有leetcode刷题攻略、各个类型经典题目刷题顺序、思维导图看一看一定会有所收获! ** 
122125
123126>  更过算法干货文章持续更新,可以微信搜索「代码随想录」第一时间围观,关注后,回复「Java」「C++」 「python」「简历模板」「数据结构与算法」等等,就可以获得我多年整理的学习资料。
124127
0 commit comments