Python怎么将链表旋转到右侧
发表于:2025-02-03 作者:千家信息网编辑
千家信息网最后更新 2025年02月03日,本篇内容介绍了"Python怎么将链表旋转到右侧"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!For
千家信息网最后更新 2025年02月03日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安全错误
数据库的锁怎样保障安全
上海r740服务器批发
淄博在线学习软件开发价格
北京候鸟网络技术
北京电通网络技术有限公司
宁夏网络安全 竞赛
徐氏易学软件开发中心
数据库文件修改
奉贤区服务器精密空调安装
攻击mc服务器
数据库安全管理和备份与恢复
三级网络技术是什么题库
夏津中医院 网络安全
农行乌镇互联网智能科技银行
软件开发计划评审级别
计算机系软件开发最难吗
农村集体使用权数据库
深圳前端软件开发大概要多少钱
游戏服务器多进程数据管理
直读数据库技术
PPT课件软件开发
科技互联网私募
没有网络安全刘没有国家安全
网络安全手抄报图片很难
数据库技术增删改查
命令行窗口连接数据库
ad管理文件服务器的权限
电商系统软件开发机构
云播服务器 搭建
意识形态工作 网络安全
移动终端软件开发需要考哪些证书