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

旋转链表(C++解法)

题目

给你一个链表的头节点 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]

C++代码

#include <iostream>
using namespace std;//创建链表结构体
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) {}
};/*
* 旋转链表问题
* 先算出链表的长度,将最后一个节点指向头节点形成环状链表
* 计算旋转后链表需要断开的位置,断开链表,返回新链表
*/
ListNode* rotateRight(ListNode* head, int k) {if (k == 0 || head == nullptr || head->next == nullptr) {return head;}int n = 1;ListNode* iter = head;while (iter->next != nullptr) {n++;iter = iter->next;}iter->next = head;int add = n - k % n;if (add == n) {return head;}while (add) {iter = iter->next;add--;}ListNode* ans = iter->next;iter->next = nullptr;return ans;
}int main() {ListNode* n1 = new ListNode(1);ListNode* n2 = new ListNode(2);ListNode* n3 = new ListNode(3);ListNode* n4 = new ListNode(4);ListNode* n5 = new ListNode(5);n1->next = n2;n2->next = n3;n3->next = n4;n4->next = n5;n5->next = nullptr;ListNode* head = n1;int k = 2;ListNode* ans = rotateRight(head, k);while (ans) {cout << ans->val << " ";ans = ans->next;}delete n1, n2, n3, n4, n5;return 0;
}

分析

旋转链表问题,先算出链表的长度,将最后一个节点指向头节点形成环状链表,计算旋转后链表需要断开的位置,断开链表,返回新链表。

http://www.lryc.cn/news/217638.html

相关文章:

  • AcWing 134:双端队列
  • Spring Cloud Gateway 重写 URL
  • 【C语法学习】10 - scanf()函数
  • ffmpeg mp3截取命令,视频与mp3合成带音频视频命令
  • 文件夹还在,里面文件没了?问题这样解决
  • 使用 OpenCV 和 Tesseract OCR 进行车牌识别
  • What exactly are the practices involved in DevOps?
  • Spring底层原理(五)
  • 算法的基本概念(数据结构与算法)
  • 高阶数据结构学习——LRU Cache
  • 代码冲突解决
  • c/c++程序的内存开辟时 的内存情况
  • 【linux常用命令+vi编辑器_2023.11.3】
  • okhttp post请求 header post参数加密遇到的两个问题
  • 什么是Webpack的loader和plugin?它们的作用是什么?
  • ESXi for ARM 最新下载地址
  • 2. 网络之网络编程
  • 工作数字化的中国历程 | 从 OA 到 BPM 到数字流程自动化
  • 6-1 二叉排序树查找操作
  • 服务上千家企业,矩阵通2.0重磅上线,全链路管理新媒体矩阵
  • 【代码随想录】算法训练计划11
  • Jmeter之JSR223
  • c++23中的新功能之十八新增的属性
  • 动手学深度学习:1.线性回归从0开始实现
  • 【计算机网络】应用层
  • python 深度学习 解决遇到的报错问题9
  • 能源管理系统为什么选择零代码开发平台?
  • 【LeetCode】剑指 Offer Ⅱ 第8章:树(12道题) -- Java Version
  • 利用maven的dependency插件将项目依赖从maven仓库中拷贝到一个指定的位置
  • 在Flask中实现文件上传七牛云中并下载