C++ 旋转链表
2021/12/29 9:08:03
本文主要是介绍C++ 旋转链表,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
//给定链表的头节点,旋转链表,将链表每个节点往右移动 k 个位置,原链表后 k 个位置的节点则依次移动到链表头。 //即,例如链表 : 1->2->3->4->5 k = 2 则返回链表 4->5->1->2->3 //数据范围:链表中节点数满足n: 0 - 1000, k: 0 ~ 10^9 //难点:新链与旧链的链头链尾处理 ListNode* rotateLinkedList(ListNode* head, int k) { int len = 0; ListNode * p = head; for (; p; ++len, p = p->next);//先遍历一次,获得链表长度 if (len == 0) return head; p = head; k = k % len;//找出真正需要旋转的节点个数 if (k == 0) return head; int length = len - k - 1; for (int i = 0; i < length; ++i, p = p->next); ListNode* headNew = p->next;//保留链头 p->next = nullptr;//将新链尾与新链头断开 p = headNew; while (p->next) { p = p->next; }//遍历至旧链尾 p->next = head;//将旧链尾与旧链头连接,形成一条新链 return headNew; }
这篇关于C++ 旋转链表的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-10-04el-table 开启定时器下,表格的选中状态会消失是什么原因-icode9专业技术文章分享
- 2024-10-03如何安装和初始化飞牛私有云 fnOS?-icode9专业技术文章分享
- 2024-10-03如何安装 App 并连接到飞牛 NAS?-icode9专业技术文章分享
- 2024-10-03如何安装飞牛 TV 并连接到影视服务器?-icode9专业技术文章分享
- 2024-10-03如何在PVE和ESXI上安装飞牛私有云 fnOS?-icode9专业技术文章分享
- 2024-10-03fnOS国产最强NAS安装系统异常情况处理-icode9专业技术文章分享
- 2024-10-03飞牛NAS如何创建存储空间?-icode9专业技术文章分享
- 2024-10-03fnOS国产最强NAS硬盘会自动休眠吗?-icode9专业技术文章分享
- 2024-10-03fnOS国产最强NAS如何安装飞牛影视和创建媒体库?-icode9专业技术文章分享
- 2024-10-03fnOS国产最强NAS如何为家人朋友开通影视账号?-icode9专业技术文章分享