地址:点击打开链接
要求翻转单链表,我想的是新建一个栈,然后遍历两边链表,第一遍值入栈,第二遍逐个出栈赋值即可
答案:
# Definition for singly-linked list.
# class ListNode(object):
# def __init__(self, x):
# self.val = x
# self.next = None
class Solution(object):
def reverseList(self, head):
"""
:type head: ListNode
:rtype: ListNode
"""
if head == None or head.next == None:
return head
begin = head
after = head
valuesList = []
valuesList.append(begin.val)
while begin != None:
valuesList.append(begin.val)
begin = begin.next
while after != None:
after.val = valuesList.pop(0)
after = after.next
return head