Python怎么将链表旋转到右侧
发表于:2025-12-02 作者:千家信息网编辑
千家信息网最后更新 2025年12月02日,本篇内容介绍了"Python怎么将链表旋转到右侧"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!For
千家信息网最后更新 2025年12月02日Python怎么将链表旋转到右侧
本篇内容介绍了"Python怎么将链表旋转到右侧"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
For example:
Given
1->2->3->4->5->NULL and k = 2
return
4->5->1->2->3->NULL
题目: 给定一个链表,通过k(非负)节点将链表旋转到右侧。
解读: 一直感觉这个题目的表述有些问题。我是这样理解才做对题的:保留后k个节点,比如example给出的k=2,那么保留4->5,前面的3个节点1->2->3右移到后面,形成新链表4->5->1->2->3。除此之外,k值也有可能是大于链表长度的,需要取余,获得真实的位移。
Language : c
/** * Definition for singly-linked list. * struct ListNode { * int val; * struct ListNode *next; * }; */struct ListNode* rotateRight(struct ListNode* head, int k) {int index = 0;int listlength = 1;struct ListNode *newlist = (struct ListNode *)malloc(sizeof(struct ListNode));struct ListNode *tail = (struct ListNode *)malloc(sizeof(struct ListNode));if(head == NULL){return NULL; } tail = head; newlist = head;while(tail->next){ //计算链表长度tail = tail->next; listlength++; } k = k % listlength; //k可能大于链表的长度if(k == 0){ //k等于链表长度,不旋转return head; } k = listlength - k; //移动前面listlength-k个节点到右侧,后k个节点不动tail->next = head; //尾节点连接首节点for(index; index < k-1; index++){ //找都新链表头newlist = newlist->next; } head = newlist->next; //新链表头newlist->next = NULL; //链表结尾赋值NULLreturn head; //返回链表头结点}Language : cpp
/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode(int x) : val(x), next(NULL) {} * }; */class Solution {public: ListNode* rotateRight(ListNode* head, int k) {if(head == NULL){return NULL; } ListNode *tail = head;int listlength = 1;while(tail->next){ //计算链表长度tail = tail->next; listlength++; } k = k % listlength; //k可能大于链表的长度if(k == 0){ //k等于链表长度,不旋转return head; } k = listlength - k; //移动前面listlength-k个节点到右侧,后k个节点不动tail->next = head; //尾节点连接首节点ListNode *newlist = head;for(int index = 0; index < k-1; index++){ //找都新链表头newlist = newlist->next; } head = newlist->next; //新链表头newlist->next = NULL; //链表结尾赋值NULLreturn head; //返回链表头结点}};Language:python
# Definition for singly-linked list.# class ListNode(object):# def __init__(self, x):# self.val = x# self.next = Noneclass Solution(object):def rotateRight(self, head, k):""" :type head: ListNode :type k: int :rtype: ListNode """if not head:return Nonetail = head listlength = 1while tail.next: tail = tail.next listlength += 1k = k % listlengthif k == 0:return head k = listlength - k tail.next = head newlist = headfor each in range(k - 1): newlist = newlist.next head = newlist.next newlist.next = Nonereturn head
"Python怎么将链表旋转到右侧"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!
节点
长度
右侧
表头
内容
更多
知识
结点
题目
移动
实用
学有所成
接下来
困境
实际
情况
感觉
文章
案例
编带
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
方舟为什么加入不了朋友的服务器
工业数据库处理流程
网络安全节目2020年
正元图形转数据库
华为麦芒4无法连接服务器网速慢
土壤环境基础数据库
塔防三国志 服务器
mysql 数据库版本号
物流管理系统数据库下载
福建数据网络技术资费
软件开发环境一般指啥
网络安全从业网
浪潮服务器虚拟化建设
渝中区常规软件开发流程特点
pb管道数据库错误
北京电子软件开发哪家便宜
闵行区项目软件开发服务大概费用
网络技术电话是什么交换
查询access数据库
数据库二进制十进制存储影响
华美云服务器怎么给op
软件开发过程时间
物流信息管理系统数据库
东莞武夷山软件开发
中国五大数据库有哪些
为什么老是提示打印机服务器错误
多线程数据库连接不安全
源码棋牌软件开发
上海交通信息安全学院数据库
国家如何管理网络安全