python 链表反转 :
单链表的反转可以使用循环,也可以使用递归的方式
1.循环反转单链表
循环的方法中,使用pre指向前一个结点,cur指向当前结点,每次把cur->next指向pre即可。
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;
leetcode:
反转一个单链表: 英文版:https://leetcode.com/problems/reverse-linked-list/description/
中文版:https://leetcode-cn.com/problems/reverse-linked-list/description/
在安利一门 很好的课程 极客时间 用python 讲解 数据结构和算法的视频 FaceBook大神讲解面试题: