Python怎么反转单链表
发表于:2025-01-26 作者:千家信息网编辑
千家信息网最后更新 2025年01月26日,这篇文章主要介绍"Python怎么反转单链表",在日常操作中,相信很多人在Python怎么反转单链表问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"Python怎么反转单
千家信息网最后更新 2025年01月26日Python怎么反转单链表
这篇文章主要介绍"Python怎么反转单链表",在日常操作中,相信很多人在Python怎么反转单链表问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"Python怎么反转单链表"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
题目:反转单链表,可以使用迭代或者递归的方法。
迭代的方法,简单说下就是:当迭代到最深层,返回的时候cur的地址和new_head的地址是一致的。操作cur就相当于操作new_head。head->next = NULL 就是将已经返回后的值丢掉。
Language:C
iteratively :
/** * Definition for singly-linked list. * struct ListNode { * int val; * struct ListNode *next; * }; */struct ListNode* reverseList(struct ListNode* head) {struct ListNode* pre = (struct ListNode *)malloc(sizeof(struct ListNode));struct ListNode* cur = (struct ListNode *)malloc(sizeof(struct ListNode));struct ListNode* temp = (struct ListNode *)malloc(sizeof(struct ListNode));if(head == NULL || head->next == NULL){return head; } pre = head; cur = head->next; pre->next = NULL;while(cur != NULL){ temp = cur->next; cur->next = pre; pre = cur; cur = temp; }return pre;}
recursively:
/** * Definition for singly-linked list. * struct ListNode { * int val; * struct ListNode *next; * }; */struct ListNode* reverseList(struct ListNode* head) {struct ListNode* cur = (struct ListNode *)malloc(sizeof(struct ListNode));struct ListNode* new_head = (struct ListNode *)malloc(sizeof(struct ListNode));if(head == NULL || head->next == NULL){return head; }//迭代到最深层,返回的时候cur的地址和new_head的地址是一致的。操作cur就相当于操作new_head。head->next = NULL 就是将已经返回后的值丢掉。cur = head->next; new_head = reverseList(cur); head->next = NULL; cur->next = head;return new_head;}
Language : python
# Definition for singly-linked list.# class ListNode(object):# def __init__(self, x):# self.val = x# self.next = Noneclass Solution(object):def reverseList(self, head):""" :type head: ListNode :rtype: ListNode """pre = Nonewhile head: cur = head head = head.next cur.next = pre pre = curreturn pre
到此,关于"Python怎么反转单链表"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!
地址
学习
迭代
就是
方法
一致
时候
更多
深层
帮助
实用
接下来
文章
理论
知识
篇文章
网站
资料
跟着
问题
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
西门子网络安全岗位
深圳运维服务软件开发报价
怎样清除数据库数据
德国最大网络安全研究中心
青岛网络安全装置
浦东新区管理软件开发定制价格
网络技术水平的重要性
天顶之弈无法连接服务器
数据库很难吗
数据服务开发软件开发
太原服务器回收公司推荐
上海软件开发驻场价格表
dns服务器北京联通虚拟主机
泗阳多功能网络技术大概费用
数据库系统概论数据查询报告
数据库事物日志作用
mysql加载数据库
计算机网络技术笔记排版设计
杭州多媒体博物馆软件开发
高斯数据库删除索引语法
方正软件开发系统
软件开发项目计费
怎么打开服务器iis管理器
网络安全工程师证件
软件开发专业实习工资
凌霄百科 access数据库
初学者软件开发教程
严格规范网络安全通知
辽宁新一代软件开发服务有哪些
天涯明月刀星月壁沉服务器