19 删除链表的倒数第 N 个结点

19. 删除链表的倒数第 N 个结点

中等

相关标签

相关企业

提示

给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。

 

 这段代码使用了双指针的方法,其中一个指针先走 n 步,然后两个指针一起走,直到第一个指针到达链表末尾,此时第二个指针指向的位置就是要删除的节点。

#include <stdio.h>
#include <stdlib.h>// 链表节点的定义
struct ListNode {int val;struct ListNode *next;
};// 删除链表倒数第n个节点的函数
struct ListNode* removeNthFromEnd(struct ListNode* head, int n) {// 使用双指针,首先让一个指针先走n步struct ListNode *dummy = (struct ListNode *)malloc(sizeof(struct ListNode));dummy->next = head;struct ListNode *fast = dummy;struct ListNode *slow = dummy;// 让fast指针先走n步for (int i = 0; i <= n; i++) {fast = fast->next;}// 当fast指针到达链表末尾时,slow指针就在倒数第n+1个节点while (fast != NULL) {fast = fast->next;slow = slow->next;}// 删除倒数第n个节点struct ListNode *temp = slow->next;slow->next = slow->next->next;free(temp);return dummy->next;
}// 创建链表节点
struct ListNode* createNode(int val) {struct ListNode *newNode = (struct ListNode *)malloc(sizeof(struct ListNode));newNode->val = val;newNode->next = NULL;return newNode;
}// 打印链表
void printList(struct ListNode *head) {struct ListNode *current = head;while (current != NULL) {printf("%d -> ", current->val);current = current->next;}printf("NULL\n");
}// 释放链表节点
void freeList(struct ListNode *head) {struct ListNode *current = head;while (current != NULL) {struct ListNode *temp = current;current = current->next;free(temp);}
}int main() {// 创建示例链表:[1, 2, 3, 4, 5]struct ListNode *head = createNode(1);head->next = createNode(2);head->next->next = createNode(3);head->next->next->next = createNode(4);head->next->next->next->next = createNode(5);int n = 2;printf("原始链表:");printList(head);// 删除倒数第n个节点head = removeNthFromEnd(head, n);printf("删除倒数第%d个节点后的链表:", n);printList(head);// 释放链表内存freeList(head);return 0;
}
  1. struct ListNode 定义了链表节点的结构,包含一个整数值 val 和一个指向下一个节点的指针 next

  2. removeNthFromEnd 函数用于删除链表倒数第 n 个节点。它首先创建一个虚拟头节点 dummy,并使用两个指针 fastslow 进行遍历。

  3. createNode 函数用于创建新的链表节点,并返回指向该节点的指针。

  4. printList 函数用于打印链表。

  5. freeList 函数用于释放链表的内存。

  6. main 函数中,首先创建一个示例链表 [1, 2, 3, 4, 5],然后调用 removeNthFromEnd 删除倒数第 n 个节点,并最后打印删除节点后的链表。

在这个代码中,使用了一个虚拟头节点 dummy 的原因是为了简化删除操作的处理。如果不使用虚拟头节点,而直接使用 head,则需要特别处理删除头节点的情况,因为头节点没有前一个节点。这会导致代码中需要额外的条件判断来处理删除头节点的情况,从而增加了复杂性。

通过使用虚拟头节点 dummy,可以确保链表中的每个节点都有一个前一个节点,使得删除操作的处理更加统一和简单。此外,虚拟头节点 dummy 在遍历过程中始终位于链表的开头,不会被删除,因此不会影响最终的结果。

总的来说,使用虚拟头节点 dummy 可以简化代码逻辑,提高代码的可读性和可维护性,尤其是在处理链表的边界情况时。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/467463.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java强训day20(选择题编程题)

选择题 编程题 题目1 import java.util.Scanner;public class Main { public static void main(String[] args) {Scanner sc new Scanner(System.in);String s sc.nextLine();StringBuffer ss new StringBuffer(s);System.out.println(ss.reverse());sc.close();} }

数学建模:K-means聚类手肘法确定k值(含python实现)

原理 当K-means聚类的k值不被指定时&#xff0c;可以通过手肘法来估计聚类数量。   在聚类的过程中&#xff0c;随着聚类数的增大&#xff0c;样本划分会变得更加精细&#xff0c;每个类别的聚合程度更高&#xff0c;那么误差平方和&#xff08;SSE&#xff09;会逐渐变小&am…

有趣儿的组件(HTML/CSS)

分享几个炫酷的组件&#xff0c;起飞~~ 评论区留爪&#xff0c;继续分享哦~ 文章目录 1. 按钮2. 输入3. 工具提示4. 单选按钮5. 加载中 1. 按钮 HTML&#xff1a; <button id"btn">Button</button>CSS&#xff1a; button {padding: 10px 20px;text-tr…

Python中多种生成随机密码超实用实例

前言 密码是信息安全的基石&#xff0c;它用于保护我们的账户、数据和隐私。为了确保密码足够强大&#xff0c;需要生成随机密码。在本文中&#xff0c;将讨论多种Python方法&#xff0c;用于生成随机密码的实用示例和技巧。 目录 ​编辑 前言 密码生成的要求 使用secrets…

给你介绍一款适合教培行业的手机软件,很好用,关键还是免费的

给你介绍一款适合教培行业的手机软件&#xff0c;很好用&#xff0c;关键还是免费的&#xff0c;DT浏览器不同于普通意义上的浏览器&#xff0c;DT的含义就是数据资料的意思&#xff0c;更专注于资料的收集和管理&#xff0c;是一款资料管理类的浏览器&#xff0c;也是一款面向…

【教3妹学编程-算法题】大于等于顺序前缀和的最小缺失整数

2哥 : 叮铃铃&#xff0c;3妹&#xff0c;过年干嘛呢&#xff0c;是不是逛吃逛吃&#xff0c;有没有长胖呢。 3妹&#xff1a;切&#xff0c;我妈张罗着要给我相亲呢。 2哥 : 相亲&#xff1f;哈哈哈哈 3妹&#xff1a;别笑了&#xff0c;我妈说跟我年龄相等的人都已经孩子上小…

autojs通过正则表达式获取带有数字的text内容

视频连接 视频连接 参考 参考 var ctextMatches(/\d/).findOne()console.log("当前金币"c.text()) // 获取当前金币UiSelector.textMatches(reg) reg {string} | {Regex} 要满足的正则表达式。 为当前选择器附加控件"text需要满足正则表达式reg"的条件。 …

(2024,扩散,多概念擦除,概念无关表示生成,权重解耦)扩散模型中可分离的多概念擦除

Separable Multi-Concept Erasure from Diffusion Models 公和众和号&#xff1a;EDPJ&#xff08;进 Q 交流群&#xff1a;922230617 或加 VX&#xff1a;CV_EDPJ 进 V 交流群&#xff09; 目录 0. 摘要 1. 简介 2. 相关工作 3. 方法 3.1. G-CiRs 3.2. 权重解耦&#…

模型 “焦糖布丁”理论

系列文章 主要是 分享 思维模型&#xff0c;涉及各个领域&#xff0c;重在提升认知。关注需求本质。 1 “焦糖布丁”理论的应用 1.1 “焦糖布丁”理论-海底捞的创新 海底捞以其优质的服务而闻名&#xff0c;它的成功之处在于深刻理解了消费者的需求和任务&#xff0c;并提供了…

算法沉淀——链表(leetcode真题剖析)

算法沉淀——链表 01.两数相加02.两两交换链表中的节点03.重排链表04.合并 K 个升序链表05.K个一组翻转链表 链表常用技巧 1、画图->直观形象、便于理解 2、引入虚拟"头节点" 3、要学会定义辅助节点&#xff08;比如双向链表的节点插入&#xff09; 4、快慢双指针…

Codeforces Round 923 (Div. 3) C. Choose the Different Ones(Java)

比赛链接&#xff1a;Round 923 (Div. 3) C题传送门&#xff1a;C. Choose the Different Ones! 题目&#xff1a; ** Example** ** input** 6 6 5 6 2 3 8 5 6 5 1 3 4 10 5 6 5 6 2 3 4 5 6 5 1 3 8 10 3 3 3 4 1 3 5 2 4 6 2 5 4 1 4 7 3 4 4 2 1 4 2 2 6 4 4 2 1 5 2 3 …

【Java程序设计】【C00270】基于Springboot的moba类游戏攻略分享平台(有论文)

基于Springboot的moba类游戏攻略分享平台&#xff08;有论文&#xff09; 项目简介项目获取开发环境项目技术运行截图 项目简介 这是一个基于Springboot的游戏攻略分享平台 本系统分为系统功能模块、管理员功能模块、以及用户后台功能模块。 系统功能模块&#xff1a;在平台首…