循環リンクリストの先頭に新しいノードを挿入するPythonプログラム
循環リンクリストの先頭に新しいノードを挿入する必要がある場合は、「Node」クラスを作成する必要があります。このクラスには、ノードに存在するデータと、リンクリストの次のノードへのアクセスという2つの属性があります。
循環リンクリストでは、ヘッドとリアが互いに隣接しています。それらは円を形成するように接続されており、最後のノードに「NULL」値はありません。
初期化関数を持つ別のクラスを作成する必要があり、ノードのヘッドは「なし」に初期化されます。
リンクリストの先頭にノードを追加し、ノード値を出力するために、ユーザーは複数のメソッドを定義します。
以下は同じのデモンストレーションです-
例
class Node:
def __init__(self,data):
self.data = data
self.next = None
class list_creation:
def __init__(self):
self.head = Node(None)
self.tail = Node(None)
self.head.next = self.tail
self.tail.next = self.head
def add_at_beginning(self,my_data):
new_node = Node(my_data);
if self.head.data is None:
self.head = new_node;
self.tail = new_node;
new_node.next = self.head;
else:
temp = self.head;
new_node.next = temp;
self.head = new_node;
self.tail.next = self.head;
def print_it(self):
curr = self.head;
if self.head is None:
print("The list is empty");
return;
else:
print(curr.data),
while(curr.next != self.head):
curr = curr.next;
print(curr.data),
print("\n");
class circular_linked_list:
my_cl = list_creation()
print("Values are being added to the list")
my_cl.add_at_beginning(21);
my_cl.print_it();
my_cl.add_at_beginning(53);
my_cl.print_it();
my_cl.add_at_beginning(76);
my_cl.print_it(); 出力
Values are being added to the list 21 53 21 76 53 21
説明
- 「Node」クラスが作成されます。
- 必要な属性を持つ別のクラスが作成されます。
- 「add_at_beginning」という名前の別のメソッドが定義されています。これは、最初に、つまり「head」ノードの前に、循環リンクリストにデータを追加するために使用されます。
- 循環リンクリストのノードを表示する「print_it」という名前の別のメソッドが定義されています。
- 'list_creation'クラスのオブジェクトが作成され、そのオブジェクトでメソッドが呼び出されてデータが追加されます。
- 'init'メソッドが定義されており、循環リンクリストの最初と最後のノードがNoneになります。
- 「add_at_beginning」メソッドが呼び出されます。
- リンクリストの先頭を取得し、その前に要素を追加して、そのアドレスをテールポインタと次のポインタに参照します。
- これは、「print_it」メソッドを使用してコンソールに表示されます。
-
循環リンクリストの要素を並べ替えるPythonプログラム
循環リンクリストの要素を並べ替える必要がある場合は、「ノード」クラスを作成する必要があります。このクラスには、ノードに存在するデータと、リンクリストの次のノードへのアクセスという2つの属性があります。 循環リンクリストでは、ヘッドとリアが互いに隣接しています。それらは円を形成するように接続されており、最後のノードに「NULL」値はありません。 初期化関数を持つ別の「linked_list」クラスを作成する必要があり、ノードのヘッドは「None」に初期化されます。 リンクリストにノードを追加し、リンクリストを昇順または降順で並べ替え、ノード値を出力するために、ユーザーは複数のメソッドを定義
-
循環リンクリスト内の要素を検索するPythonプログラム
循環リンクリストで要素を検索する必要がある場合は、「ノード」クラスを作成する必要があります。このクラスには、ノードに存在するデータと、リンクリストの次のノードへのアクセスという2つの属性があります。 循環リンクリストでは、ヘッドとリアが互いに隣接しています。それらは円を形成するように接続されており、最後のノードに「NULL」値はありません。初期化関数を持つ別のクラスを作成する必要があり、ノードのヘッドは「なし」に初期化されます。 リンクリストにノードを追加したり、リンクリストで特定のノードを検索したり、ノード値を出力したりするために、ユーザーは複数のメソッドを定義します。 以下は同じのデ