[Leetcode 206]链表之单链表反转

本文提供了使用Python和Golang两种语言实现链表数据结构的方法,并详细展示了如何通过编程技巧完成链表的反转操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Python实现:

用Python实现链表总觉着有点尴尬

class ListNode:
     def __init__(self, x):
         self.val = x
         self.next = None

class Solution:
    def reverseList(self, head):
        if (head is None or head.next is None):
            return head

        head_tmp=None
        tmp=head
        while (tmp !=None):
            next_tmp=tmp.next
            tmp.next=head_tmp
            head_tmp=tmp
            tmp=next_tmp

        return head_tmp

def printlist(head):
    while(head !=None):
        print(head.val)
        head=head.next

p1=ListNode(1)
p2=ListNode(2)
p3=ListNode(3)
p4=ListNode(4)
p1.next=p2
p2.next=p3
p3.next=p4

printlist(p1)
print('**********************')
x=Solution()
pr=x.reverseList(head=p1)
printlist(pr)

Golang实现

package main

import "fmt"

  type ListNode struct {
      Val int
      Next *ListNode
  }

func reverseList(head *ListNode) *ListNode {
   if head==nil || head.Next==nil{
      return head
   }
   var head_tmp *ListNode
   var tmp *ListNode
   var next_tmp *ListNode
   tmp=head
   for tmp !=nil{
      next_tmp=tmp.Next
      tmp.Next=head_tmp
      head_tmp=tmp
      tmp=next_tmp
   }
   return head_tmp

}

func printlist(head *ListNode){
   for {
      if head == nil {
         break

      }

         fmt.Println(head.Val)
         head=head.Next

   }

}

func main() {
   var rl1 *ListNode =new(ListNode)
   var l1 *ListNode = &ListNode{
      Val:1,
      Next:nil,
   }
   var l2 *ListNode = &ListNode{
      Val:2,
      Next:nil,
   }
   var l3 *ListNode = &ListNode{
      Val:3,
      Next:nil,
   }
   var l4 *ListNode = &ListNode{
      Val:4,
      Next:nil,
   }
   l1.Next=l2
   l2.Next=l3
   l3.Next=l4

   printlist(l1)
   fmt.Println("*******")
   rl1=reverseList(l1)
   printlist(rl1)

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值