返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C++怎么旋转链表
  • 262
分享到

C++怎么旋转链表

2023-06-19 12:06:25 262人浏览 独家记忆
摘要

这篇文章主要介绍“c++怎么旋转链表”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C++怎么旋转链表”文章能帮助大家解决问题。Rotate List 旋转链表Given the head&

这篇文章主要介绍“c++怎么旋转链表”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C++怎么旋转链表”文章能帮助大家解决问题。

Rotate List 旋转链表

Given the head of a linked list, rotate the list to the right by k places.

Example 1:

C++怎么旋转链表

Input: head = [1,2,3,4,5], k = 2
Output: [4,5,1,2,3]

Example 2:

C++怎么旋转链表

Input: head = [0,1,2], k = 4
Output: [2,0,1]

Constraints:

  • The number of nodes in the list is in the range [0, 500].

  • -100 <= Node.val <= 100

  • 0 <= k <= 2 * 109

这道旋转链表的题和之前那道 Rotate Array 很类似,但是比那道要难一些,因为链表的值不能通过下表来访问,只能一个一个的走,博主刚开始拿到这题首先想到的就是用快慢指针来解,快指针先走k步,然后两个指针一起走,当快指针走到末尾时,慢指针的下一个位置是新的顺序的头结点,这样就可以旋转链表了,自信满满的写完程序,放到 OJ 上跑,以为能一次通过,结果跪在了各种特殊情况,首先一个就是当原链表为空时,直接返回NULL,还有就是当k大于链表长度和k远远大于链表长度时该如何处理,需要首先遍历一遍原链表得到链表长度n,然后k对n取余,这样k肯定小于n,就可以用上面的算法了,代码如下:

 解法一:

class Solution {public:    ListNode *rotateRight(ListNode *head, int k) {        if (!head) return NULL;        int n = 0;        ListNode *cur = head;        while (cur) {            ++n;            cur = cur->next;        }        k %= n;        ListNode *fast = head, *slow = head;        for (int i = 0; i < k; ++i) {            if (fast) fast = fast->next;        }        if (!fast) return head;        while (fast->next) {            fast = fast->next;            slow = slow->next;        }        fast->next = head;        fast = slow->next;        slow->next = NULL;        return fast;    }};

这道题还有一种解法,跟上面的方法类似,但是不用快慢指针,一个指针就够了,原理是先遍历整个链表获得链表长度n,然后此时把链表头和尾链接起来,在往后走 n - k%n 个节点就到达新链表的头结点前一个点,这时断开链表即可,代码如下:

class Solution {public:    ListNode *rotateRight(ListNode *head, int k) {        if (!head) return NULL;        int n = 1;        ListNode *cur = head;        while (cur->next) {            ++n;            cur = cur->next;        }        cur->next = head;        int m = n - k % n;        for (int i = 0; i < m; ++i) {            cur = cur->next;        }        ListNode *newhead = cur->next;        cur->next = NULL;        return newhead;    }};

关于“C++怎么旋转链表”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网其他教程频道,小编每天都会为大家更新不同的知识点。

--结束END--

本文标题: C++怎么旋转链表

本文链接: https://lsjlt.com/news/296226.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • C++怎么旋转链表
    这篇文章主要介绍“C++怎么旋转链表”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C++怎么旋转链表”文章能帮助大家解决问题。Rotate List 旋转链表Given the head&...
    99+
    2023-06-19
  • C++实现旋转链表
    这篇文章主要介绍“C++实现旋转链表”,在日常操作中,相信很多人在C++实现旋转链表问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C++实现旋转链表”的疑惑有所帮助!接下来,请跟着小编一起来学习吧![Leet...
    99+
    2023-06-20
  • C++实现LeetCode(61.旋转链表)
    [LeetCode] 61. Rotate List 旋转链表 Given the head of a linked list, rotate the ...
    99+
    2024-04-02
  • Python 数据结构之旋转链表
    题目描述:给定一个链表,旋转链表,使得每个节点向右移动k个位置,其中k是一个非负数 样例:给出链表1->2->3->4->5->null和k=2;返回4->5->...
    99+
    2022-06-04
    数据结构 链表 Python
  • C++相交链表和反转链表详解
    目录给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表没有交点,返回 null 。思路给你单链表的头节点 head ,请你反转...
    99+
    2024-04-02
  • C++怎么实现旋转数组
    本篇内容主要讲解“C++怎么实现旋转数组”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C++怎么实现旋转数组”吧!Rotate Array 旋转数组Given an array, rotate ...
    99+
    2023-06-20
  • C#中的数组怎么转化成链表
    在C#中,可以使用`LinkedList`类来将数组转换为链表。`LinkedList`类是C#中的一个内置泛型类,用于表示双向链表...
    99+
    2023-09-09
    C#
  • c语言单链表反转代码怎么写
    以下是一个简单的C语言单链表反转代码示例: #include #include // 定义链表节点结构体 typedef st...
    99+
    2023-10-26
    c语言
  • Python数据结构之旋转链表的示例分析
    这篇文章主要为大家展示了“Python数据结构之旋转链表的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Python数据结构之旋转链表的示例分析”这篇文章吧。示例图题目描述:给定一个链表...
    99+
    2023-06-17
  • golang中怎么反转链表
    这期内容当中小编将会给大家带来有关golang中怎么反转链表,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。问题:反转一个单链表。输入: 1->2->3->4->5->...
    99+
    2023-06-20
  • C++怎么划分链表
    这篇文章主要讲解了“C++怎么划分链表”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++怎么划分链表”吧!Partition List 划分链表Given a linked list an...
    99+
    2023-06-20
  • C++怎么实现每k个一组翻转链表
    本篇内容主要讲解“C++怎么实现每k个一组翻转链表”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C++怎么实现每k个一组翻转链表”吧!Reverse Nodes in k-Group 每k个一组...
    99+
    2023-06-20
  • Java反转链表怎么测试
    本篇内容主要讲解“Java反转链表怎么测试”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java反转链表怎么测试”吧!链表特点便于增删数据,不便于寻址在内存中属于跳转结构单链表和双链表的定义单链...
    99+
    2023-07-06
  • C++怎么实现单链表
    本文小编为大家详细介绍“C++怎么实现单链表”,内容详细,步骤清晰,细节处理妥当,希望这篇“C++怎么实现单链表”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。单链表链表内存空间不一定连续,其扩展性较好。多余的不多...
    99+
    2023-07-02
  • C++链表类怎么封装
    这篇文章主要介绍“C++链表类怎么封装”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C++链表类怎么封装”文章能帮助大家解决问题。1.CList.h#ifndef CLIST_H#defi...
    99+
    2023-06-30
  • java怎么实现单链表反转
    要实现单链表的反转,可以使用迭代或递归两种方法。 迭代法: public ListNode reverseList(ListNo...
    99+
    2023-10-26
    java
  • python怎么实现单向链表及单向链表的反转
    这篇文章给大家分享的是有关python怎么实现单向链表及单向链表的反转的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。链表的定义链表中的每个节点会存储相邻节点的位置信息,单链表中的每个节点只存储下一关节点的位置信息...
    99+
    2023-06-14
  • web数组与链表到单链表的反转怎么理解
    本篇内容主要讲解“web数组与链表到单链表的反转怎么理解”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“web数组与链表到单链表的反转怎么理解”吧!数组与链表数组最大的一个特点就是,需要一块连续的...
    99+
    2023-06-16
  • C++怎么实现链表排序
    本篇内容主要讲解“C++怎么实现链表排序”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C++怎么实现链表排序”吧!链表排序Sort a linked list in O(n ...
    99+
    2023-06-20
  • C#集合的链表怎么用
    这篇文章主要介绍了C#集合的链表怎么用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C#集合的链表怎么用文章都会有所收获,下面我们一起来看看吧。LinkedList<T>是一个双向链表,其元素会指向...
    99+
    2023-06-30
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作