เมื่อจำเป็นต้องค้นหาค่าโหนดสูงสุดและต่ำสุดจากรายการเชื่อมโยงแบบวงกลม จะต้องสร้างคลาส 'โหนด' ในคลาสนี้ มีแอตทริบิวต์ 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_data(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:
self.tail.next = new_node
self.tail = new_node
self.tail.next = self.head
def find_min_node(self):
curr = self.head;
min_val = self.head.data;
if(self.head == None):
print("The list is empty");
else:
while(True):
if(min_val > curr.data):
min_val = curr.data;
curr= curr.next;
if(curr == self.head):
break;
print("Minimum value node in the list: "+ str(min_val));
def find_max_node(self):
curr = self.head;
max_val = self.head.data;
if(self.head == None):
print("List is empty");
else:
while(True):
if(max_val < curr.data):
max_val = curr.data;
curr= curr.next;
if(curr == self.head):
break;
print("The maximum valueed node is : "+ str(max_val));
class circular_linked_list:
my_cl = list_creation()
print("Values have been added to the list")
my_cl.add_data(11)
my_cl.add_data(52)
my_cl.add_data(36)
my_cl.add_data(74)
my_cl.find_max_node()
my_cl.find_min_node() ผลลัพธ์
Values have been added to the list The maximum valueed node is : 74 Minimum value node in the list: 11
คำอธิบาย
- คลาส 'โหนด' ถูกสร้างขึ้น
- สร้างคลาสอื่นที่มีคุณสมบัติที่จำเป็นแล้ว
- มีการกำหนดวิธีการอื่นที่ชื่อว่า 'add_data' ซึ่งใช้ในการเพิ่มข้อมูลไปยังรายการที่เชื่อมโยงแบบวงกลม
- มีการกำหนดวิธีการอื่นที่ชื่อว่า 'find_max_node' ซึ่งจะวนซ้ำในรายการและรับค่าสูงสุดในโหนด
- มีการกำหนดวิธีการอื่นที่ชื่อว่า 'find_min_node' ซึ่งจะวนซ้ำในรายการและรับค่าต่ำสุดในโหนด
- วัตถุของคลาส 'list_creation' ถูกสร้างขึ้น และมีการเรียกใช้เมธอดเพื่อเพิ่มข้อมูล
- มีการกำหนดวิธีการ 'init' ซึ่งโหนดแรกและโหนดสุดท้ายของรายการที่เชื่อมโยงแบบวงกลมเป็นไม่มี
- มีการเรียกเมธอด 'find_max_node' และเมธอด 'find_min_node'
- มันวนซ้ำผ่านโหนดในรายการที่เชื่อมโยง รับค่าสูงสุดและต่ำสุดในรายการ
- แสดงบนคอนโซล