反转链表相关的练习(上)
创始人
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;
}

图解示例二

相关内容

热门资讯

怎么才能让鹦鹉说话? 怎么才能让鹦鹉说话?不是所有鹦鹉都会说话的,虎皮 牡丹 玄凤 之类的就不会说话,虽然有些资料上介绍 ...
孙悟空在南瞻部州被称呼为什么? 孙悟空在南瞻部州被称呼为什么?孙悟空在南瞻部州被称为孙大圣。他的称呼是比较威武凶猛的。因为他的人物形...
“每一个晚上”英语怎么讲 “每一个晚上”英语怎么讲every night
我在红袖写了一篇小说,只有签约... 我在红袖写了一篇小说,只有签约,没有上架,请问怎么样才能拿到稿费,我是签网协的每天都有更新的话。。达...
王朔:这辈子最对不起老婆和女儿... 王朔:这辈子最对不起老婆和女儿,但我死后财产全归徐静蕾,这是为何呢?因为在这个人的心中,徐静蕾才是自...
游戏《天地玄门》激活账号的激活... 游戏《天地玄门》激活账号的激活码怎么写?那个游戏得发短信到腾武才会获得激活码
孩子课后作业辅导,如何让老公平... 孩子课后作业辅导,如何让老公平心静气的教孩子?可以告诉老公,孩子的辅导需要老公有耐心一些,因为孩子犯...
《阿姨暖暖你的手》阅读题答案 《阿姨暖暖你的手》阅读题答案1、“春寒料峭”和“春暖花开”都是形容春天的词语。文中第(2)段中的“春...
想找到一本有声小说,喜马拉雅有... 想找到一本有声小说,喜马拉雅有,但是我忘记名字了。讲的是茅山道士的故事,但不是紫襟讲的,我问过了?书...
郝邵文合释小龙都演过什么电影我... 郝邵文合释小龙都演过什么电影我想知道,要全的1、笑林小子(又名:旋风小子)2、笑林小子2之乌龙院3、...
林黛玉放屁拉肚子 林黛玉放屁拉肚子林黛玉放屁拉肚子是《红楼梦》中的一个情节。在小说中,林黛玉因为情绪低落和身体不适而出...
克雷洛夫寓言有哪些寓言故事?故... 克雷洛夫寓言有哪些寓言故事?故事的主要内容及道理是什么?最起码说出3个,克雷洛夫寓言有哪些寓言故事?...
请告诉我一点笑话! 请告诉我一点笑话!告诉我一点笑话便可!如此美丽夜晚孤独是一种遗憾,想念着得不到的爱情已经成为习惯,情...
樱花、新年、任性、武士、爆破、... 樱花、新年、任性、武士、爆破、缇娜、武媚娘、土豪biangbiang面、萌萌哒、小鲜肉、醉了 用以上...
东北出马仙堂怎么写 东北出马仙堂怎么写去找高人查看 ,看看是否具备出马缘分,出马仙的堂单一般都是仙 或者给你立堂的师傅给...
探访鹿邑:漫步古城,寻迹历史名... 探访鹿邑:漫步古城,寻迹历史名人之路鹿邑是一个历史悠久的古城,有着丰富的文化底蕴和历史遗迹。探访鹿邑...
类似与儒道至圣的小说 类似与儒道至圣的小说[剑三+文修]自古名士真国色[系统]国士无双
星际争霸2人族怎么防隐形?怎么... 星际争霸2人族怎么防隐形?怎么看隐形?:轨道控制基地的雷达,防空塔和渡鸦自带的反隐效果人族有4招防隐...
谁有《从零开始学画漫画》电子书... 谁有《从零开始学画漫画》电子书 谢谢亲,去狗狗书籍呗,你去新浪爱问搜搜,应该能找到》
公主日记1里有首笨爱神的歌叫什... 公主日记1里有首笨爱神的歌叫什么名字stupid cupidstupid cupidstupid c...