当前位置: 首页 > news >正文

LeetCode面试题Day18|LC61 旋转链表

题目1:

指路:

. - 力扣(LeetCode)61 旋转链表

思路与分析:

如果我没记错的话这个题应该在一次周赛上出现过,但我做题的网站太杂忘记哪一次了。对于旋转链表我的第一思路是将其做成环形链表,返回原链表中最右边的节点,剩下的依次返回,那么第一次旋转也就是原链表中倒数第一个节点旋转后的位置应该是新链表的第一个,原链表中倒数第二个节点旋转后的位置应该是倒数第二个……以此类推我们得到旋转k次以后,原链表中的首节点最后旋转完成后的位置应该是正数第k+1个,而原链表中的尾节点最后旋转完成的位置应该是正数第k个……再看样例,当n=5,k=2时从第4个节点开始返回,而n=3,k=1从第三个节点开始返回(大家也可以再写几个案例),得到一个规律那就是原链表完成k次旋转后,首节点应该是原链表的第n-k+1个位置。在这里需要注意的一点是并不是完全旋转k次,当k>n时,旋转n次即为原链表,因此我们可以直接旋转k%n次,结合上面的推导我们可以直接用一个首节点指向原链表中n-k+1的位置,最后修改新链表的首尾节点指向。

代码:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode() : val(0), next(nullptr) {}*     ListNode(int x) : val(x), next(nullptr) {}*     ListNode(int x, ListNode *next) : val(x), next(next) {}* };*/
class Solution {
public:ListNode* rotateRight(ListNode* head, int k) {if (head == nullptr || head->next == nullptr || k == 0) return head;int cnt = 1;ListNode* dummyhead = head;  // dummyhead = ori_tailwhile (dummyhead->next != nullptr) {  // 保证不是最后一个,即向后遍历有意义cnt += 1;dummyhead= dummyhead->next;}  // 遍历全部节点找到全部节点个数k %= cnt;  // 找到最少遍历的次数if ((k %= cnt )== 0) return head;// 怎么让尾节点的下一个节点指向首节点?// 直接做第二种解法ListNode* new_tail = head;for (int i = 0; i < cnt - k - 1; i++) {new_tail = new_tail->next;}ListNode* new_head = new_tail->next;// 修改链表的头尾节点指向dummyhead->next = head;new_tail->next = nullptr;return new_head;}
};


http://www.mrgr.cn/news/13364.html

相关文章:

  • Python TensorFlow入门与实践
  • Celery 中,广播模式可以通过使用 RabbitMQ 的 fanout 交换机来实现
  • JS脚本实现RPA模拟人工操作网页获取数据
  • 登录失败时刷新验证码
  • Avalonia与WPF开发时的差异总结
  • C语言基础(十二)
  • 美国短剧APP借力Facebook广告引流核心优势攻略
  • const、inline、nullptr的使用
  • Spring框架 基础介绍
  • SpringBoot核心配置文件(SpringBoot学习3)
  • 结合令牌(JWT)和签名认证的系统登录及页面访问的详细实现原理和流程
  • APP渠道来源方案探索
  • Docker培训
  • 【MySQL进阶之路】事务的隔离级别
  • 优秀的开源项目
  • MyBatis缓存机制 ▎特殊符号处理
  • 经验笔记:基于Token的身份认证及其安全性探讨
  • Elasticsearch搜索引擎
  • C语言 | Leetcode C语言题解之第374题猜数字大小
  • JWT令牌本身已包含签名,访问资源的时候为什么还需要签名认证?