Theo em, có thể dùng danh sách liên kết để biểu diễn hàng đợi hay không?
Câu 2: Theo em, có thể dùng danh sách liên kết để biểu diễn hàng đợi hay không?
Có, danh sách liên kết (linked list) có thể được sử dụng để biểu diễn hàng đợi (queue). Thực tế, việc sử dụng danh sách liên kết để biểu diễn hàng đợi mang lại nhiều lợi ích so với mảng tĩnh (array).
Lợi ích của việc sử dụng danh sách liên kết để biểu diễn hàng đợi
Kích thước linh hoạt: Danh sách liên kết không có giới hạn về kích thước như mảng tĩnh. Điều này có nghĩa là hàng đợi có thể mở rộng hoặc thu hẹp mà không cần phải xác định trước kích thước tối đa.
Thao tác nhanh: Việc thêm phần tử vào cuối danh sách (enqueue) và lấy phần tử từ đầu danh sách (dequeue) có thể được thực hiện một cách hiệu quả với độ phức tạp thời gian là O(1)O(1)O(1) nếu sử dụng danh sách liên kết đôi (doubly linked list) hoặc đơn giản (singly linked list) với con trỏ đến phần tử cuối.
Cấu trúc hàng đợi sử dụng danh sách liên kết
Trong hàng đợi sử dụng danh sách liên kết, chúng ta thường cần duy trì hai con trỏ:
front trỏ đến phần tử đầu tiên của hàng đợi.
rear trỏ đến phần tử cuối cùng của hàng đợi.
Cài đặt hàng đợi bằng danh sách liên kết đơn giản trong Python
Dưới đây là một ví dụ cài đặt hàng đợi sử dụng danh sách liên kết đơn giản (singly linked list):
class Node:
def __init__(self, data):
self.data = data
self.next = None
class Queue:
def __init__(self):
self.front = None
self.rear = None
def is_empty(self):
return self.front is None
def enqueue(self, item):
new_node = Node(item)
if self.rear is None:
self.front = self.rear = new_node
return
self.rear.next = new_node
self.rear = new_node
def dequeue(self):
if self.is_empty():
print("Hàng đợi rỗng, không thể lấy phần tử")
return None
temp = self.front
self.front = temp.next
if self.front is None:
self.rear = None
return temp.data
def peek(self):
if self.is_empty():
print("Hàng đợi rỗng, không thể lấy phần tử")
return None
return self.front.data
# Ví dụ sử dụng
queue = Queue()
queue.enqueue(10)
queue.enqueue(20)
queue.enqueue(30)
print("Phần tử đầu tiên:", queue.peek()) # Output: 10
print("Lấy phần tử ra khỏi hàng đợi:", queue.dequeue()) # Output: 10
print("Lấy phần tử ra khỏi hàng đợi:", queue.dequeue()) # Output: 20
queue.enqueue(40)
print("Phần tử đầu tiên:", queue.peek()) # Output: 30
Kết luận
Sử dụng danh sách liên kết để biểu diễn hàng đợi là một cách hiệu quả và linh hoạt, giúp thực hiện các thao tác thêm và lấy phần tử từ hàng đợi một cách nhanh chóng và tiện lợi.
Giải những bài tập khác
Giải bài tập những môn khác
Môn học lớp 12 KNTT
5 phút giải toán 12 KNTT
5 phút soạn bài văn 12 KNTT
Văn mẫu 12 KNTT
5 phút giải vật lí 12 KNTT
5 phút giải hoá học 12 KNTT
5 phút giải sinh học 12 KNTT
5 phút giải KTPL 12 KNTT
5 phút giải lịch sử 12 KNTT
5 phút giải địa lí 12 KNTT
5 phút giải CN lâm nghiệp 12 KNTT
5 phút giải CN điện - điện tử 12 KNTT
5 phút giải THUD12 KNTT
5 phút giải KHMT12 KNTT
5 phút giải HĐTN 12 KNTT
5 phút giải ANQP 12 KNTT
Môn học lớp 12 CTST
5 phút giải toán 12 CTST
5 phút soạn bài văn 12 CTST
Văn mẫu 12 CTST
5 phút giải vật lí 12 CTST
5 phút giải hoá học 12 CTST
5 phút giải sinh học 12 CTST
5 phút giải KTPL 12 CTST
5 phút giải lịch sử 12 CTST
5 phút giải địa lí 12 CTST
5 phút giải THUD 12 CTST
5 phút giải KHMT 12 CTST
5 phút giải HĐTN 12 bản 1 CTST
5 phút giải HĐTN 12 bản 2 CTST
Môn học lớp 12 cánh diều
5 phút giải toán 12 CD
5 phút soạn bài văn 12 CD
Văn mẫu 12 CD
5 phút giải vật lí 12 CD
5 phút giải hoá học 12 CD
5 phút giải sinh học 12 CD
5 phút giải KTPL 12 CD
5 phút giải lịch sử 12 CD
5 phút giải địa lí 12 CD
5 phút giải CN lâm nghiệp 12 CD
5 phút giải CN điện - điện tử 12 CD
5 phút giải THUD 12 CD
5 phút giải KHMT 12 CD
5 phút giải HĐTN 12 CD
5 phút giải ANQP 12 CD
Giải chuyên đề học tập lớp 12 kết nối tri thức
Giải chuyên đề Ngữ văn 12 Kết nối tri thức
Giải chuyên đề Toán 12 Kết nối tri thức
Giải chuyên đề Vật lí 12 Kết nối tri thức
Giải chuyên đề Hóa học 12 Kết nối tri thức
Giải chuyên đề Sinh học 12 Kết nối tri thức
Giải chuyên đề Kinh tế pháp luật 12 Kết nối tri thức
Giải chuyên đề Lịch sử 12 Kết nối tri thức
Giải chuyên đề Địa lí 12 Kết nối tri thức
Giải chuyên đề Tin học ứng dụng 12 Kết nối tri thức
Giải chuyên đề Khoa học máy tính 12 Kết nối tri thức
Giải chuyên đề Công nghệ 12 Điện - điện tử Kết nối tri thức
Giải chuyên đề Công nghệ 12 Lâm nghiệp thủy sản Kết nối tri thức
Giải chuyên đề học tập lớp 12 chân trời sáng tạo
Giải chuyên đề Ngữ văn 12 Chân trời sáng tạo
Giải chuyên đề Toán 12 Chân trời sáng tạo
Giải chuyên đề Vật lí 12 Chân trời sáng tạo
Giải chuyên đề Hóa học 12 Chân trời sáng tạo
Giải chuyên đề Sinh học 12 Chân trời sáng tạo
Giải chuyên đề Kinh tế pháp luật 12 Chân trời sáng tạo
Giải chuyên đề Lịch sử 12 Chân trời sáng tạo
Giải chuyên đề Địa lí 12 Chân trời sáng tạo
Giải chuyên đề Tin học ứng dụng 12 Chân trời sáng tạo
Giải chuyên đề Khoa học máy tính 12 Chân trời sáng tạo
Giải chuyên đề Công nghệ 12 Điện - điện tử Chân trời sáng tạo
Giải chuyên đề Công nghệ 12 Lâm nghiệp thủy sản Chân trời sáng tạo
Giải chuyên đề học tập lớp 12 cánh diều
Giải chuyên đề Ngữ văn 12 Cánh diều
Giải chuyên đề Toán 12 Cánh diều
Giải chuyên đề Vật lí 12 Cánh diều
Giải chuyên đề Hóa học 12 Cánh diều
Giải chuyên đề Sinh học 12 Cánh diều
Giải chuyên đề Kinh tế pháp luật 12 Cánh diều
Giải chuyên đề Lịch sử 12 Cánh diều
Giải chuyên đề Địa lí 12 Cánh diều
Giải chuyên đề Tin học ứng dụng 12 Cánh diều
Giải chuyên đề Khoa học máy tính 12 Cánh diều
Giải chuyên đề Công nghệ 12 Điện - điện tử Cánh diều
Giải chuyên đề Công nghệ 12 Lâm nghiệp thủy sản Cánh diều
Bình luận