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)
- res:=L1
- 次の解像度:=solve(次のL1、次のL2)
理解を深めるために、次の実装を見てみましょう-
例
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, ]
-
Pythonを使用してリンクリストとして指定された2つの多項式を追加するプログラム
2つの多項式が与えられ、2つの多項式の加算を見つける必要があるとします。多項式は、リンクリストとして表す必要があります。多項式の項は、リンクリストノードとして表されます。各リンクリストノードには、係数値、電力値、および次のリンクリストノードへのポインターが含まれます。 2つのリンクリスト多項式を追加した3番目のリンクリストを返す必要があります。 したがって、入力が次のような場合 1x ^ 1 + 1x ^ 2=0および2x^1 + 3x ^ 0 =0、 その場合、出力は3x ^ 1 + 1x ^ 2 + 3x ^ 0 =0になります。 これを解決するには、次の手順に従います-
-
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