力扣61.旋转链表

给你一个链表的头节点 head ,旋转链表,将链表每个节点向右移动 k个位置。

示例 1:

复制代码
输入:head = [1,2,3,4,5], k = 2
输出:[4,5,1,2,3]

示例 2:

复制代码
输入:head = [0,1,2], k = 4
输出:[2,0,1]

提示:

  • 链表中节点的数目在范围 [0, 500]
  • -100 <= Node.val <= 100
  • 0 <= k <= 2 * 109

题目分析

该题给出应该链表,以及应该正整数,要求我们将链表中的节点向前移k个位置,这题我们可以转换思想就会变得很简单。

解题思路

我们可以通过遍历链表,计算出链表的长度,并且将链表首尾连接起来,因为给出的正整数k又可能大于链表的长度n,所以我们需要计算指针在一圈里面需要走多少,所以求得k除n的余数。因为遍历链表后,此时指针位于链表的尾部,如果此时需要向前移俩个单位,我们可以理解为:要把后面的俩个节点移到最前面。则在遍历环的时候,走到这俩个节点前,断开环,则我们可以得到目标链表。

复制代码
struct ListNode* rotateRight(struct ListNode* head, int k) {
    if(k == 0 || head == NULL || head->next ==NULL){
        return head;
    }
    int n=1;
    struct ListNode* cur = head;
    while(cur->next != NULL) {
        cur = cur->next;
        n++;
    }
    int add = n - k % n;
    if(add == n) {
        return head;
    }
    cur->next = head;//连接该链表的首尾
    while(add--) {
        cur = cur->next;
    }
    struct ListNode* prev = cur->next;
    cur->next = NULL;
    return prev;
}

总结

在最近做链表题中我觉得链表题中,应该有以下注意点

  1. 做题判断有没有特殊情况,比如该题当正整数为0或链表长度为0或1的时候,就无需判断直接返回结果即可,这会简便我们的程序。
  2. 我们要注意节点的变换和遍历链表的方式,指针的移动,如果这些无法处理好可能会导致死循环。
相关推荐
长安——归故李2 分钟前
【modbus学习】
java·c语言·c++·学习·算法·c#
兴科Sinco28 分钟前
[leetcode 1]给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出和为目标值 target 的那两个整数[力扣]
python·算法·leetcode
沐怡旸29 分钟前
【算法--链表】138.随机链表的复制--通俗讲解
算法·面试
anlogic35 分钟前
Java基础 9.10
java·开发语言·算法
薛定谔的算法38 分钟前
JavaScript单链表实现详解:从基础到实践
数据结构·算法·leetcode
CoovallyAIHub1 小时前
CostFilter-AD:用“匹配代价过滤”刷新工业质检异常检测新高度! (附论文和源码)
深度学习·算法·计算机视觉
幻奏岚音1 小时前
《数据库系统概论》第一章 初识数据库
数据库·算法·oracle
你好,我叫C小白1 小时前
贪心算法(最优装载问题)
算法·贪心算法·最优装载问题
CoovallyAIHub1 小时前
CVPR 2025 | 频率动态卷积(FDConv):以固定参数预算实现频率域自适应,显著提升视觉任务性能
深度学习·算法·计算机视觉
mit6.8241 小时前
[rStar] 解决方案节点 | `BaseNode` | `MCTSNode`
人工智能·python·算法