Leetcode练习(Python):链表类:第206题:反转链表:反转一个单链表。
Posted 桌子哥
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Leetcode练习(Python):链表类:第206题:反转链表:反转一个单链表。相关的知识,希望对你有一定的参考价值。
题目:
反转链表:反转一个单链表。
进阶:
你可以迭代或递归地反转链表。你能否用两种方法解决这道题?
你可以迭代或递归地反转链表。你能否用两种方法解决这道题?
思路:
思路一:使用栈的思想。
思路二:使用迭代。
思路三:使用递归。
程序1:
# Definition for singly-linked list.
# class ListNode:
# def __init__(self, x):
# self.val = x
# self.next = None
class Solution:
def reverseList(self, head: ListNode) -> ListNode:
if not head:
return None
myStack = list()
myNode = head
while myNode:
myStack.append(myNode.val)
myNode = myNode.next
myNewHead = ListNode(myStack.pop())
myNode2 = myNewHead
while len(myStack):
myNode2.next = ListNode(myStack.pop())
myNode2 = myNode2.next
#myNode2.next = null
return myNewHead
程序2:
class Solution:
def reverseList(self, head: ListNode) -> ListNode:
if not head:
return None
index1 = head
while index1.next:
index2 = ListNode(index1.next.val)
index2.next = head
head = index2
index1.next = index1.next.next
return head
程序3:
class Solution:
def reverseList(self, head: ListNode) -> ListNode:
if head == None or head.next == None:
return head
newListNode = self.reverseList(head.next)
head.next.next = head
head.next = None
return newListNode
以上是关于Leetcode练习(Python):链表类:第206题:反转链表:反转一个单链表。的主要内容,如果未能解决你的问题,请参考以下文章
Leetcode练习(Python):链表类:第61题:旋转链表:给定一个链表,旋转链表,将链表每个节点向右移动 k 个位置,其中 k 是非负数。
Leetcode练习(Python):链表类:第143题:重排链表:给定一个单链表 L:L0→L1→…→Ln-1→Ln , 将其重新排列后变为: L0→Ln→L1→Ln-1→L2→Ln-2→
Leetcode练习(Python):链表类:第23题:合并K个排序链表:合并 k 个排序链表,返回合并后的排序链表。请分析和描述算法的复杂度。
Leetcode练习(python):链表类:第82题:删除排序链表中的重复元素 II:给定一个排序链表,删除所有含有重复数字的节点,只保留原始链表中 没有重复出现 的数字。
Leetcode练习(Python):链表类:第19题:删除链表的倒数第N个节点:给定一个链表,删除链表的倒数第 n 个节点,并且返回链表的头结点。说明: 给定的 n 保证是有效的。
Leetcode练习(Python):链表类:第237题:删除链表中的节点:请编写一个函数,使其可以删除某个链表中给定的(非末尾)节点,你将只被给定要求被删除的节点。