反转链表相关的练习(上)
创始人
2024-05-31 03:34:37
0

目录

一、反转链表

二、反转链表 ||

三、两两交换链表中的结点

四、K 个一组翻转链表



一、反转链表

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。

示例 1

 输入:head = [1,2,3,4,5]

输出:[5,4,3,2,1]

示例 2

 输入:head = [1,2]

输出:[2,1]

示例 3

输入:head = []

输出:[]

提示

  • 链表中节点的数目范围是 [0, 5000]

  • -5000 <= Node.val <= 5000

代码实现一

struct ListNode* reverseList(struct ListNode* head)
{struct ListNode* pre = NULL;struct ListNode* cur = head;while (cur != NULL){struct ListNode* after = cur->next;cur->next = pre;pre = cur;cur = after;}return pre;
}

代码实现二(将结点依次头插到新链表中)

struct ListNode* reverseList(struct ListNode* head)
{struct ListNode* newhead = NULL;struct ListNode* cur = head;while (cur != NULL){struct ListNode* after = cur->next;// 头插cur->next = newhead;newhead = cur;cur = after;} return newhead;
}


二、反转链表 ||

给你单链表的头指针 head 和两个整数 leftright ,其中 left <= right 。请你反转从位置 left 到位置 right 的链表节点,返回 反转后的链表

示例 1

 输入:head = [1,2,3,4,5], left = 2, right = 4

输出:[1,4,3,2,5]

示例 2

输入:head = [5], left = 1, right = 1

输出:[5]

提示

  • 链表中节点数目为 n

  • 1 <= n <= 500

  • -500 <= Node.val <= 500

  • 1 <= left <= right <= n

进阶: 你可以使用一趟扫描完成反转吗?

代码实现

struct ListNode* reverseBetween(struct ListNode* head, int left, int right)
{struct ListNode* guard = (struct ListNode*)malloc(sizeof(struct ListNode));guard->next = head;struct ListNode* tmp = guard;// 1. 让 tmp 指向第 left - 1 个结点(不包括哨兵位的头结点)for (int i = 0; i < left - 1; ++i){tmp = tmp->next;}// 2. 反转从位置 left 到位置 right 的链表结点struct ListNode* pre = tmp->next;struct ListNode* cur = pre->next;for (int i = 0; i < right - left; ++i){struct ListNode* after = cur->next;cur->next = pre;pre = cur;cur = after;}// 经过反转,tmp->next 指向的结点变成了从位置 left 到位置 right 中最后一个结点,// 而 pre 指向的结点则变成了第一个结点tmp->next->next = cur;  // (1)tmp->next = pre;  // (2)head = guard->next;free(guard);return head;
}

图解示例一

 


三、两两交换链表中的结点

给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。

示例 1

 输入:head = [1,2,3,4]

输出:[2,1,4,3]

示例 2

输入:head = []

输出:[]

示例 3

输入:head = [1]

输出:[1]

提示

  • 链表中节点的数目在范围 [0, 100]

  • 0 <= Node.val <= 100

代码实现

struct ListNode* swapPairs(struct ListNode* head)
{// 创建一个哨兵位的头结点struct ListNode* guard = (struct ListNode*)malloc(sizeof(struct ListNode));guard->next = head;// 交换 tmp 后面的两个结点struct ListNode* tmp = guard;while (tmp->next && tmp->next->next){struct ListNode* node1 = tmp->next;struct ListNode* node2 = tmp->next->next;tmp->next = node2;  // (1)node1->next = node2->next;  // (2)node2->next = node1;  // (3)// 更新 tmptmp = node1;}head = guard->next;free(guard);return head;
}


四、K 个一组翻转链表

给你链表的头节点 head ,每 k 个节点一组进行翻转,请你返回修改后的链表。

k 是一个正整数,它的值小于或等于链表的长度。如果节点总数不是 k 的整数倍,那么请将最后剩余的节点保持原有顺序。

你不能只是单纯的改变节点内部的值,而是需要实际进行节点交换。

示例 1

 输入:head = [1,2,3,4,5], k = 2

输出:[2,1,4,3,5]

示例 2

 输入:head = [1,2,3,4,5], k = 3

输出:[3,2,1,4,5]

提示

  • 链表中的节点数目为 n

  • 1 <= k <= n <= 5000

  • 0 <= Node.val <= 1000

代码实现

struct ListNode* reverseKGroup(struct ListNode* head, int k)
{struct ListNode* guard = (struct ListNode*)malloc(sizeof(struct ListNode));guard->next = head;struct ListNode* tmp = guard;while (1){// 判断剩余长度是否大于或等于 kstruct ListNode* p = tmp;for (int i = 0; p != NULL && i < k; ++i){p = p->next;}if (p == NULL){break;}// 翻转 tmp 后面的 k 个结点struct ListNode* pre = tmp->next;struct ListNode* cur = pre->next;for (int i = 0; i < k - 1; ++i){struct ListNode* after = cur->next;cur->next = pre;pre = cur;cur = after;}// 经过翻转后,tmp->next 指向的结点变成了最后一个结点,// 而 pre 指向的结点则变成成了第一个结点tmp->next->next = cur;  // (1)struct ListNode* last = tmp->next;  // 保存最后一个结点的地址tmp->next = pre;  // (2)// 更新 tmptmp = last;}head = guard->next;free(guard);return head;
}

图解示例二

相关内容

热门资讯

谁能给我发几个好看的穿越文,女... 谁能给我发几个好看的穿越文,女主要聪明点的,还有请给我发下《蛇蝎皇后》这篇小说我有比较多的小说,但是...
网络语叫粉丝是什么意思? 网络语叫粉丝是什么意思?'粉丝’是英语‘Fans’(狂热、热爱之意,后引申为影迷、追星等意思)的音译...
你们希望柯南的最后大结局是新兰... 你们希望柯南的最后大结局是新兰永恒吗肯定滴啊,如果新兰都不永恒了谁还相信爱情、、、 上次预告还有五年...
出师表朗诵 出师表朗诵出师表的朗诵应该配上什么音乐,或者歌曲(最好是现代的),给点建议!新三国片头曲吧试试王宗贤...
《率土之滨》平民新手开局怎么玩... 《率土之滨》平民新手开局怎么玩?前期开荒核心是完美的利用每一点资源,把他变为你前期最有利的抢地武器!...
咒怨里面的白老妇[那个鬼 的扮... 咒怨里面的白老妇[那个鬼 的扮演者是谁?告诉我吧求求你们了 我要是不知道他是活人演的拿篮球的那个老婆...
体验当家的辛苦 体验当家的辛苦自己体会会有灵感的。什么事情还是自己做一下比较真实这样的作文就必须要自己去亲身体会,让...
(只要人物时间地点的正确就能开... (只要人物时间地点的正确就能开启尘封已久的记忆)能解释一下这个是什么含义是一个女的写给我的是表白吗大...
科学和迷信你们信哪个?不能解释... 科学和迷信你们信哪个?不能解释的东西事物算得上是迷信吗迷信我是不会相信的,如果对所谓的科学百分之百的...
请问延世大学韩语教程和标准韩国... 请问延世大学韩语教程和标准韩国语哪本更适合自学?哪本语法更详细,更易于学习。先谢谢啦。你好,标准韩国...
有谁曾经暗恋一个人,很久都没有... 有谁曾经暗恋一个人,很久都没有见到却还是很想念他想就想呗,随自己的意就可以了让她留在心里吧.我也曾暗...
昨天在车上看的碟子,好像是,一... 昨天在车上看的碟子,好像是,一个DJ现场,一个人边唱边喝酒,还互动问题,答完就喝。提问的歌曲有:洪湖...
魔兽世界小白任务和战场问题 魔兽世界小白任务和战场问题去魔兽数据库里找 多玩 嘟牛 这两个网站的 数据库很全 什么任务...
《公主回宫》什么时候开播? 《公主回宫》什么时候开播?已经开播了,祝你愉快.
到底大灰狼和小绵羊是一对,还是... 到底大灰狼和小绵羊是一对,还是和小白兔是一对很显然小绵羊和小白兔是一对
你觉着《他来了请闭眼》中霍建华... 你觉着《他来了请闭眼》中霍建华演技如何?《他来了请闭眼》中霍建华演技很好。霍建华的演技很好,能够表现...
九色神鹿故事? 九色神鹿故事?很久以前,在恒河边上有一只九种毛色的鹿,它那闪闪发光的鲜艳毛色和洁白如雪的美丽鹿角,以...
刘州成坚强的故事 刘州成坚强的故事就是男子汉一点的 刘小美的刘州成他是一个很坚强的人来的.. 一路走来他都是勇敢地走来...
书籍设计的内容简介 书籍设计的内容简介《书籍设计》立足于新世纪中国艺术教育的改革,将艺术理论与技能培训融会贯通,从内容选...
2024年山西中考初二考地理生... 2024年山西中考初二考地理生物吗不考。截止2022年6月1日山西中考除晋中和阳泉两个改革试点区域外...