Python
 Computer >> コンピューター >  >> プログラミング >> Python

Pythonで2つの与えられたリンクリストの結合を見つけるプログラム


2つのソートされたリンクリストL1とL2があるとすると、2つの指定されたリストの和集合である新しいソートされたリンクリストを返す必要があります。

したがって、入力がL1 =[10,20,30,40,50,60,70] L2 =[10,30,50,80,90]の場合、出力は[10、20、30 40、50、60、70、80、90、]

これを解決するには、次の手順に従います-

  • 関数solve()を定義します。これにはL1、L2が必要です
  • L1が空の場合、
    • L2を返す
  • L2が空の場合、
    • L1を返す
  • L1の値
  • res:=L1
  • 次の解像度:=solve(次のL1、L2)
  • それ以外の場合、L2の値
  • res:=L2
  • 次の解像度:=solve(次のL2、L1)
  • それ以外の場合、
    • res:=L1
    • 次の解像度:=solve(次のL1、次のL2)
  • return res
  • 理解を深めるために、次の実装を見てみましょう-

    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, L1, L2):
          if not L1:
             return L2
          if not L2:
             return L1
          if L1.val < L2.val:
             res = L1
             res.next = self.solve(L1.next, L2)
          elif L2.val < L1.val:
             res = L2
             res.next = self.solve(L2.next, L1)
          else:
             res = L1
             res.next = self.solve(L1.next, L2.next)
       return res
    ob = Solution()
    L1 = make_list([10,20,30,40,50,60,70])
    L2 = make_list([10,30,50,80,90])
    print_list(ob.solve(L1, L2))

    入力

    [10,20,30,40,50,60,70], [10,30,50,80,90]

    出力

    [10, 20, 30, 40, 50, 60, 70, 80, 90, ]

    1. Pythonを使用してリンクリストとして指定された2つの多項式を追加するプログラム

      2つの多項式が与えられ、2つの多項式の加算を見つける必要があるとします。多項式は、リンクリストとして表す必要があります。多項式の項は、リンクリストノードとして表されます。各リンクリストノードには、係数値、電力値、および次のリンクリストノードへのポインターが含まれます。 2つのリンクリスト多項式を追加した3番目のリンクリストを返す必要があります。 したがって、入力が次のような場合 1x ^ 1 + 1x ^ 2=0および2x^1 + 3x ^ 0 =0、 その場合、出力は3x ^ 1 + 1x ^ 2 + 3x ^ 0 =0になります。 これを解決するには、次の手順に従います-

    2. 2つのリストの共通部分を見つけるPythonプログラム?

      交差演算とは、リスト1とリスト2からすべての共通要素を取得する必要があり、すべての要素が別の3番目のリストに格納されることを意味します。 List1::[1,2,3] List2::[2,3,6] List3::[2,3] アルゴリズム Step 1: input lists. Step 2: first traverse all the elements in the first list and check with the elements in the second list. Step 3: if the elements are matched then store in t