日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python怎么反转单链表_单链表反转python实现代码示例

發布時間:2025/3/15 python 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python怎么反转单链表_单链表反转python实现代码示例 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

單鏈表的反轉可以使用循環,也可以使用遞歸的方式

1.循環反轉單鏈表

循環的方法中,使用pre指向前一個結點,cur指向當前結點,每次把cur->next指向pre即可。

代碼:

class ListNode:

def __init__(self,x):

self.val=x;

self.next=None;

def nonrecurse(head): #循環的方法反轉鏈表

if head is None or head.next is None:

return head;

pre=None;

cur=head;

h=head;

while cur:

h=cur;

tmp=cur.next;

cur.next=pre;

pre=cur;

cur=tmp;

return h;

head=ListNode(1); #測試代碼

p1=ListNode(2); #建立鏈表1->2->3->4->None;

p2=ListNode(3);

p3=ListNode(4);

head.next=p1;

p1.next=p2;

p2.next=p3;

p=nonrecurse(head); #輸出鏈表 4->3->2->1->None

while p:

print p.val;

p=p.next;

結果:

4

3

2

1

>>>

2.遞歸實現單鏈表反轉

class ListNode:

def __init__(self,x):

self.val=x;

self.next=None;

def recurse(head,newhead): #遞歸,head為原鏈表的頭結點,newhead為反轉后鏈表的頭結點

if head is None:

return ;

if head.next is None:

newhead=head;

else :

newhead=recurse(head.next,newhead);

head.next.next=head;

head.next=None;

return newhead;

head=ListNode(1); #測試代碼

p1=ListNode(2); # 建立鏈表1->2->3->4->None

p2=ListNode(3);

p3=ListNode(4);

head.next=p1;

p1.next=p2;

p2.next=p3;

newhead=None;

p=recurse(head,newhead); #輸出鏈表4->3->2->1->None

while p:

print p.val;

p=p.next;

運行結果同上。

總結

以上就是本文關于單鏈表反轉python實現代碼示例的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續參閱本站其他相關專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!

總結

以上是生活随笔為你收集整理的python怎么反转单链表_单链表反转python实现代码示例的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。