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

Pythonでリストの最後からN番目のノードを削除する


リンクリストがあるとします。リストの最後からN番目のノードを削除してから、そのヘッドを返す必要があります。したがって、リストが[1、2、3、4、5、6]のようで、n =3の場合、返されるリストは[1、2、3、5、6]になります。

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

  • ヘッドの後にノードがない場合は、Noneを返します
  • フロント:=ヘッド、バック:=ヘッド、カウンター:=0、ファウント:=false
  • while counter <=n
    • フロントが存在しない場合は、フラグをtrueに設定し、ループから抜け出します
    • フロント:=フロントの次、カウンターを1増やします
  • フロントが存在する間
    • フロント:=フロントの次
    • 戻る:=次の後ろ
  • フラグがfalseの場合、
    • temp:=次の後ろ
    • next of back:=next of temp
    • 次の臨時雇用者:=なし
  • それ以外の場合、頭:=頭の次
  • リターンヘッド
例(Python)

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

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(object):
   def removeNthFromEnd(self, head, n):
      if not head.next:
         return None
      front=head
      back = head
      counter = 0
      flag = False
      while counter<=n:
         if(not front):
            flag = True
            break
         front = front.next
         counter+=1
      while front:
         front = front.next
         back = back.next
      if not flag:
         temp = back.next
         back.next = temp.next
         temp.next = None
      else:
         head = head.next
      return head
head = make_list([1,2,3,4,5,6])
ob1 = Solution()
print_list(ob1.removeNthFromEnd(head, 3))

入力

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

出力

[1,2,3,5,6]

  1. Python –すべての要素がNoneであるリストからタプルを削除します

    すべての要素がNoneであるリストからタプルを削除する必要がある場合は、リスト内包表記と「all」演算子が使用されます。 以下は同じのデモンストレーションです- 例 my_tuple = [(None, 12), (None, None), (33, 54), (32, 13), (None, )] print("The tuple is :") print(my_tuple) my_result = [index for index in my_tuple if not all(element == None for element in index)] prin

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

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