Python怎么将链表旋转到右侧
发表于:2024-11-19 作者:千家信息网编辑
千家信息网最后更新 2024年11月19日,本篇内容介绍了"Python怎么将链表旋转到右侧"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!For
千家信息网最后更新 2024年11月19日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安全错误
数据库的锁怎样保障安全
oasys实时数据库配置
ifile网页服务器
徐汇区创新软件开发销售电话
邮政软件开发中心加班情况
数据库不见了怎样把菜单栏平铺
求代理服务器地址
黄冈定制软件开发企业
2014年科技互联网红利
如何看数据库状态对不对
滨江开发区软件开发公司
魔兽 hg服务器
小软件开发交易
java模拟数据库插数据
邮箱设置收件服务器
经济技术开发区彩湖网络技术
怎么查出这台服务器走了哪些线路
云端服务器能换ip么
英国大学邮箱服务器设置
妆点app服务器繁忙
网络安全信息培训内容
数据库单选按钮在哪
网络安全监控是什么
厂家服务器维修方法视频
sql数据库题目详细操作
计算机网络技术大数据运维
tzb国际网络安全团队
计算机网络包括网络安全么
软件开发的延伸行业
究极数码进化服务器
数据库系统概论王珊电子版教材