链表OJ 1移除链表元素val
来源:https://leetcode.cn/problems/remove-linked-list-elements/description/
题目:
方法一:定义prev和cur指针(双指针)
分析:
使用两个指针prev和cur来遍历链表。prev指针指向当前节点的前一个节点,而cur指针指向当前节点。
在 while 循环中,首先检查当前节点的值是否等于val。如果相等,则需要移除该节点。
如果当前节点的值不等于val,则将prev更新为cur, cur 更新为下一个节点,以继续遍历链表。
思路一:prev不为NULL
- 如果 prev 不为 NULL,表示当前节点不是头节点,则将 prev->next 指向当前节点的下一个节点,然后释放当前节点 cur 的内存,并更新cur为 prev->next ,即下一个要检查的节点。
思路二: prev 为 NULL
- 如果 prev 为 NULL,表示当前节点是头节点,则将 cur 更新为头节点的下一个节点,释放头节点 head 的内存,并更新 head 为新的头节点 cur。
最后,返回更新后的链表头指针 head
该代码的目的是移除链表中所有值为 val 的节点,同时释放相应的内存。
代码实现:
-
struct ListNode* removeElements(struct ListNode* head, int val)
-
{
-
struct ListNode* prev = NULL, * cur = head;
-
while (cur)
-
{
-
if (cur->val == val)
-
{
-
if (prev)
-
{
-
prev->next = cur->next;
-
free(cur);
-
cur = prev->next;
-
}
-
else
-
{
-
cur = head->next;
-
free(head);//会把指针域next给free掉,因为它也是结构体的成员
-
head = cur;
-
}
-
}
-
else
-
{
-
prev = cur;
-
cur = cur->next;
-
}
-
}
-
return head;
-
}
执行:
方法二:链表尾插
大致思路:
移除链表中所有值为val的节点,并使用尾插法构建一个新的链表,返回新链表的头指针。原始链表中不满足条件的节点会被保留,而满足条件的节点会被移除并释放内存。
尾插的思路:
函数使用三个指针cur、newhead 和 tail 来遍历和构建新的链表。
在 while 循环中,首先检查当前节点的值是否等于 val 。如果不等于 val ,则执行尾插操作将该节点添加到新链表中。
顺序:
- 如果 tail 为 NULL,表示当前节点是新链表的第一个节点。将newhead和 tail 都指向当前节点cur
- 接着,将 cur 更新为下一个节点,并将 tail->next 设置为 NULL,确保新链表断开
此时 tail
不为 NULL,表示当前节点需要添加到新链表的尾部。将 tail->next 指向当前节点 cur ,然后更新 tail 为 tail->next,新链表链接起来实现尾插。- 接着持续2的操作
如果当前节点的值等于 val ,则需要移除该节点。将 cur 更新为下一个节点,并释放当前节点 del 的内存。
最后,返回新链表的头指针 newhead
画图:
代码实现:
-
//尾插
-
struct ListNode* removeElements(struct ListNode* head,int val)
-
{
-
struct ListNode*cur=head;
-
struct ListNode *newhead=NULL,*tail=NULL;
-
while(cur)
-
{
-
if(cur->val!=val)
-
{
-
if(tail==NULL)
-
{
-
newhead=tail=cur;
-
}
-
else
-
{
-
tail->next=cur;
-
tail=tail->next;
-
}
-
cur=cur->next;// 这两条语句不可以调换顺序,否则tail->next=null
-
tail->next=NULL;//cur=cur->next,这样写的话会尾插失败
-
}
-
else
-
{
-
struct ListNode*del=cur;
-
cur=cur->next;
-
free(del);//会把指针域next给free掉,因为它也是结构体的成员
-
}
-
}
-
return newhead;
-
}
代码执行:
好了博客就分享到这里了,感谢你的来访!
这篇好文章是转载于:学新通技术网
- 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
- 本站站名: 学新通技术网
- 本文地址: /boutique/detail/tanhgcgjch
系列文章
更多
同类精品
更多
-
photoshop保存的图片太大微信发不了怎么办
PHP中文网 06-15 -
Android 11 保存文件到外部存储,并分享文件
Luke 10-12 -
word里面弄一个表格后上面的标题会跑到下面怎么办
PHP中文网 06-20 -
《学习通》视频自动暂停处理方法
HelloWorld317 07-05 -
photoshop扩展功能面板显示灰色怎么办
PHP中文网 06-14 -
微信公众号没有声音提示怎么办
PHP中文网 03-31 -
excel下划线不显示怎么办
PHP中文网 06-23 -
excel打印预览压线压字怎么办
PHP中文网 06-22 -
怎样阻止微信小程序自动打开
PHP中文网 06-13 -
TikTok加速器哪个好免费的TK加速器推荐
TK小达人 10-01