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

Pythonのリンクリストから特定のターゲットの最後の出現を削除するプログラム


単一リンクリストがあり、targetという別の値があるとすると、指定されたリストで最後に出現したtargetを削除する必要があります。

したがって、入力が[5,4,2,6,5,2,3,2,4,5,4,7]、target =5の場合、出力は[5、4、2、6 、5、2、3、2、4、4、7、]

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

  • ヘッド:=ノード
  • k:=null、prev:=null
  • found:=False
  • ノードがnullでない場合は、
    • ノードの値がターゲットと同じである場合、
      • found:=True
      • prev:=k
    • k:=ノード
    • node:=ノードの次
  • 見つかったがFalseの場合、
    • リターンヘッド
  • prevがnullの場合、
    • 次の頭に戻る
  • 前のnect:=前の次の次
  • リターンヘッド

理解を深めるために、次の実装を見てみましょう-

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, target):
      head = node
      k = None
      prev = None
      found = False
      while node:
         if node.val == target:
            found = True
         prev = k
         k = node
         node = node.next
         if found == False:
            return head
         if not prev:
            return head.next
            prev.next = prev.next.next
      return head
ob = Solution()
L = make_list([5,4,2,6,5,2,3,2,4,5,4,7])
target = 5
print_list(ob.solve(L, target))

入力

[5,4,2,6,5,2,3,2,4,5,4,7]

出力

[5, 4, 2, 6, 5, 2, 3, 2, 4, 4, 7, ]

  1. リスト内のxの前にある各yオカレンスを削除するPythonプログラム

    リスト内の「x」の前にあるすべての「y」を削除する必要がある場合は、「インデックス」メソッドとともにリスト内包表記が使用されます。 例 以下は同じもののデモンストレーションです my_list = [4, 45, 75, 46, 66, 77, 48, 99, 10, 40, 5, 8] print("The list is :") print(my_list) a, b = 8, 4 index_a = my_list.index(a) my_result = [ele for index, ele in enumerate(my_list) if ele !=

  2. Pythonのリンクリストからmノードの後に​​nノードを削除するプログラム

    開始ノードが「head」で、2つの整数mとnを持つリンクリストが与えられたとします。リストをトラバースして、最初のmノードがリストに保持され、最初のmノードが削除された後の次のnノードなどのいくつかのノードを削除する必要があります。リンクリストの最後に到達するまでこれを実行します。ヘッドノードから開始し、変更されたリンクリストが返されます。 リンクリスト構造は-として与えられます Node    value : <integer>    next : <pointer to next node> したがって、入力が要素=[1、