再帰を使用してリンクリスト内の代替ノードを印刷するPythonプログラム
再帰を使用してリンクリスト内の代替ノードを印刷する必要がある場合、リンクリストに要素を追加する方法、リンクリストの要素を表示する方法、およびリンクリストの代替値を取得する方法は次のとおりです。定義されています。以前に定義されたメソッドを呼び出して代替値を取得する別のヘルパー関数が使用されます。
以下は同じのデモンストレーションです-
例
class Node: def __init__(self, data): self.data = data self.next = None class my_linked_list: def __init__(self): self.head = None self.last_node = None def add_value(self, my_data): if self.last_node is None: self.head = Node(my_data) self.last_node = self.head else: self.last_node.next = Node(my_data) self.last_node = self.last_node.next def print_it(self): curr = self.head while curr: print(curr.data) curr = curr.next def alternate_nodes(self): self.alternate_helper_fun(self.head) def alternate_helper_fun(self, curr): if curr is None: return print(curr.data, end = ' ') if curr.next: self.alternate_helper_fun(curr.next.next) my_instance = my_linked_list() my_list = input("Enter the elements of the linked list :").split() for elem in my_list: my_instance.add_value(elem) print("The alternate elements in the linked list are :") my_instance.alternate_nodes()
出力
Enter the elements of the linked list :78 56 34 52 71 96 0 80 The alternate elements in the linked list are : 78 34 71 0
説明
-
「Node」クラスが作成されます。
-
必要な属性を持つ別の「my_linked_list」クラスが作成されます。
-
最初の要素を初期化するために使用される「init」関数があります。つまり、「head」を「None」に、最後のノードを「None」に初期化します。
-
リンクリストにデータを追加するために使用される「add_value」という名前の別のメソッドが定義されています。
-
「print_it」という名前の別のメソッドが定義されており、リストを繰り返し処理して要素を出力します。
-
ヘルパー関数を呼び出すために使用される「alternate_nodes」という名前の別のメソッドが定義されています。
-
「alternate_helper_fun」という名前の別のヘルパー関数が定義されています。これは、リンクリストを反復処理し、代替インデックスで要素を表示するために使用されます。
-
これは再帰関数であるため、何度も自分自身を呼び出します。
-
再帰が使用されているため、これは「alternate_nodes」関数を呼び出すために使用されます。
-
「my_linked_list」クラスのオブジェクトが作成されます。
-
代替要素を表示するために、alternate_nodesメソッドが呼び出されます。
-
この出力はコンソールに表示されます。
-
C ++で再帰を使用して、リンクリストの代替ノードを出力します
リンクリストは、要素を連続していないメモリ位置に格納する線形データ構造です。すべての要素には、リンクリストの次の要素へのポインタが含まれています。 例 − この問題では、リンクリストが与えられ、このリンクリストの要素を印刷する必要がありますが、代替要素のみが印刷されます。問題をよりよく理解するために例を見てみましょう。 Input : 2 -> 4 -> 1 -> 67 -> 48 -> 90 Output : 2 -> 1 -> 48 説明 −リンクリストに代替要素を出力します。したがって、1番目、3番目、5番目の要素が印刷されます。
-
循環リンクリストの要素を並べ替えるPythonプログラム
循環リンクリストの要素を並べ替える必要がある場合は、「ノード」クラスを作成する必要があります。このクラスには、ノードに存在するデータと、リンクリストの次のノードへのアクセスという2つの属性があります。 循環リンクリストでは、ヘッドとリアが互いに隣接しています。それらは円を形成するように接続されており、最後のノードに「NULL」値はありません。 初期化関数を持つ別の「linked_list」クラスを作成する必要があり、ノードのヘッドは「None」に初期化されます。 リンクリストにノードを追加し、リンクリストを昇順または降順で並べ替え、ノード値を出力するために、ユーザーは複数のメソッドを定義