Python程式:交替從連結串列頭尾轉換節點


假設我們有一個單鏈表,我們需要重新排列它,使得我們依次取:最後一個節點,然後是第一個節點,然後是倒數第二個節點,然後是第二個節點,以此類推。

所以,如果輸入是 [1,2,3,4,5,6,7,8,9],那麼輸出將是 [9, 1, 8, 2, 7, 3, 6, 4, 5]

為了解決這個問題,我們將遵循以下步驟

  • c := 節點

  • l := 新列表

  • 當 c 不為空時,執行

    • 將 c 的值插入到 l 的末尾

    • c := c 的下一個節點

    • c := 節點

    • 當 c 不為空且 l 不為空時,執行

      • c 的值 := l 中最後一個元素的值,並將其刪除

      • c := c 的下一個節點

      • 如果 c 為空,則

        • 退出迴圈

      • c 的值 := l 中最後一個元素的值,並將其刪除

      • c := c 的下一個節點

  • 返回節點

讓我們看看下面的實現,以便更好地理解

示例

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

def make_list(elements):
   head = ListNode(elements[0])
   for element in elements[1:]:
      ptr = head
      while ptr.next:
         ptr = ptr.next
      ptr.next = ListNode(element)

   return head

def print_list(head):
   ptr = head
   print('[', end = "")
   while ptr:
      print(ptr.val, end = ", ")
      ptr = ptr.next
   print(']')

class Solution:
   def solve(self, node):
      c = node
      l = []
      while c:
         l.append(c.val)
         c = c.next

      c = node
      while c and l:
         c.val = l.pop()
         c = c.next
         if c == None:
            break
         c.val = l.pop(0)
         c = c.next
      return node

ob = Solution()
head = make_list([1,2,3,4,5,6,7,8,9])
print_list(ob.solve(head))

輸入

[1,2,3,4,5,6,7,8,9]

輸出

[9, 1, 8, 2, 7, 3, 6, 4, 5, ]

更新於: 2020年11月10日

126 次瀏覽

開啟你的職業生涯

完成課程獲得認證

開始學習
廣告
© . All rights reserved.