C语言怎么删除链表中的节点
发表于:2025-02-09 作者:千家信息网编辑
千家信息网最后更新 2025年02月09日,这篇文章主要讲解了"C语言怎么删除链表中的节点",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"C语言怎么删除链表中的节点"吧!请编写一个函数,使其可以删
千家信息网最后更新 2025年02月09日C语言怎么删除链表中的节点
这篇文章主要讲解了"C语言怎么删除链表中的节点",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"C语言怎么删除链表中的节点"吧!
请编写一个函数,使其可以删除某个链表中给定的(非末尾)节点,你将只被给定要求被删除的节点。
现有一个链表 -- head = [4,5,1,9],它可以表示为:
4 -> 5 -> 1 -> 9
示例 1:
输入: head = [4,5,1,9], node = 5
输出: [4,1,9]
解释: 给定你链表中值为 5 的第二个节点,那么在调用了你的函数之后,该链表应变为 4 -> 1 -> 9.
示例 2:
输入: head = [4,5,1,9], node = 1
输出: [4,5,9]
解释: 给定你链表中值为 1 的第三个节点,那么在调用了你的函数之后,该链表应变为 4 -> 5 -> 9.
说明:
链表至少包含两个节点。
链表中所有节点的值都是唯一的。
给定的节点为非末尾节点并且一定是链表中的一个有效节点。
不要从你的函数中返回任何结果。
上期的问题是:165,二叉搜索树的最近公共祖先
1public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
2 while ((root.val - p.val) * (root.val - q.val) > 0)
3 root = p.val < root.val ? root.left : root.right;
4 return root;
5}
解析:
这个很好理解,只要while循环为true,那么p和q要么都在root的左子树中,要么都在root的右子树中,所以继续往下找。当while中的循环为false的时候,那么p和q要么一个在root的左子树一个在root的右子树,要么p和q其中的一个是另一个的祖先节点(当while中条件语句的前面等于0的时候)。我们还可以改为递归的方式
1public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
2 return (root.val - p.val) * (root.val - q.val) <=0 ? root :
3 lowestCommonAncestor(p.val < root.val ? root.left : root.right, p, q);
4}
感谢各位的阅读,以上就是"C语言怎么删除链表中的节点"的内容了,经过本文的学习后,相信大家对C语言怎么删除链表中的节点这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!
节点
语言
函数
要么
子树
学习
中值
内容
时候
末尾
示例
祖先
问题
应变
循环
解释
输入
输出
有效
三个
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全法实施的方案
赣南日报网络安全
战地3皓月平台服务器进不去
网络安全相关儿歌
信丰软件开发
怎么打开scopus数据库
Redis写入数据库语句
四川高原网络安全宣讲
旬阳网络安全宣传
广东安防时间频率同步服务器
广州大学网络安全实训
远洋服务器
软件开发先调研还是先招标
浙江台州首选dns服务器怎么填
微动网络技术
第一届红帽杯网络安全大赛
广爱网络技术有限公司
国铁集团网络安全工作由科信部
ibm服务器电源功率
大学的软件开发团队分工
IT软件开发的
灰烬使者服务器炸了
上海直销网络技术调试
数据库都有什么技术指标
义乌web渗透网络安全培训
发布网络安全信息
数据库补考试题
A3战士装备数据库
福州安卓软件开发
国家管网网络安全招标公告