已解决
删除链表中所有含有val的节点
来自网友在路上 171871提问 提问时间:2023-09-19 06:29:13阅读次数: 71
最佳答案 问答题库718位专家为你答疑解惑
给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val == val 的节点,并返回 新的头节点 。
示例 1:
输入:head = [1,2,6,3,4,5,6], val = 6
输出:[1,2,3,4,5]
思路1:遍历查找,找到一个删一个
代码:
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>struct ListNode
{int val;struct ListNode* next;
};struct ListNode* removeElements(struct ListNode* head, int val){struct ListNode* cur = head;struct ListNode* pre = NULL;while (cur != NULL){if (cur->val == val){if (cur == head){head = cur->next;free(cur);cur = head;}else{pre->next = cur->next;free(cur);cur = pre->next;}}else{pre = cur;cur = cur->next;}}return head;
}
int main()
{struct ListNode* n1= (struct ListNode* )malloc(sizeof(struct ListNode));struct ListNode* n2 = (struct ListNode*)malloc(sizeof(struct ListNode));struct ListNode* n3 = (struct ListNode*)malloc(sizeof(struct ListNode));struct ListNode* n4 = (struct ListNode*)malloc(sizeof(struct ListNode));n1->val = 7;n2->val = 6;n3->val = 7;n4->val = 6;n1->next = n2;n2->next = n3;n3->next = n4;n4->next = NULL;struct ListNode* head= removeElements(n1,7);struct ListNode* cur = head;while (cur){printf("%d->", cur->val);cur = cur->next;}printf("NULL");return 0;
}
思路而,重新定义一个头节点指针=NULL;遍历链表把不等于val的节点移到新的头指针节点处,新城新的链表
代码:
struct ListNode* removeElements1(struct ListNode* head, int val)
{struct ListNode* cur = head;struct ListNode* newhead = NULL;struct ListNode* tail = NULL;while (cur){if (cur->val == val){struct ListNode* pre = cur;cur = cur->next;free(pre);}else{if (tail == NULL){newhead = tail = cur;}else{tail->next = cur;tail = tail->next;}cur = cur->next;}if(tail)tail->next = NULL;}
}
查看全文
99%的人还看了
相似问题
- 〖大前端 - 基础入门三大核心之JS篇㊲〗- DOM改变元素节点的css样式、HTML属性
- Java 算法篇-链表的经典算法:判断回文链表、判断环链表与寻找环入口节点(“龟兔赛跑“算法实现)
- 代码随想录二刷 | 链表 | 删除链表的倒数第N个节点
- 节点导纳矩阵
- bhosts 显示节点 “unreach“ 状态
- 电子电器架构 —— 车载网关边缘节点总线转换
- 〖大前端 - 基础入门三大核心之JS篇㊳〗- DOM访问元素节点
- 第四天||24. 两两交换链表中的节点 ● 19.删除链表的倒数第N个节点 ● 面试题 02.07. 链表相交 ● 142.环形链表II
- CS224W5.1——消息传递和节点分类
- Vue报错解决Error in v-on handler: “Error: 无效的节点选择器:#div1“
猜你感兴趣
版权申明
本文"删除链表中所有含有val的节点":http://eshow365.cn/6-9152-0.html 内容来自互联网,请自行判断内容的正确性。如有侵权请联系我们,立即删除!
- 上一篇: JS的WebAPI
- 下一篇: android去掉 原生锁屏