Câu hỏi:

13/07/2024 107

Thiết lập hàng đợi và các thao tác cơ bản với hàng đợi từ mảng T

Sách mới 2k7: Bộ 20 đề minh họa Toán, Lí, Hóa, Văn, Sử, Địa…. form chuẩn 2025 của Bộ giáo dục (chỉ từ 110k).

20 đề Toán 20 đề Văn Các môn khác

Quảng cáo

Trả lời:

verified
Giải bởi Vietjack

Thiết lập hàng đợi và các thao tác cơ bản với hàng đợi từ mảng T như sâu:

- Để thiết lập dữ liệu hàng đợi từ mảng T cho trước cần có thêm biến backldx mô tả chỉ số của phần tử đuôi của hàng đợi. Ban đầu thiết lập backldx = -1 tương ứng với hàng đợi rỗng.

- Cần viết thêm hàm isFullQueue(Q) kiểm tra xem hàng đợi đã đầy chưa. Hàm trả về True nếu hàng đợi Q đã đầy (backIdx = N-1), ngược lại trả về False.

Để thiết lập hàng đợi từ mảng TTT và thực hiện các thao tác cơ bản với hàng đợi, ta có thể làm như sau:

- Khởi tạo hàng đợi từ mảng TTT.

- Thiết lập biến backIdx để theo dõi chỉ số của phần tử đuôi của hàng đợi.

- Viết các hàm kiểm tra hàng đợi có đầy không, thêm phần tử vào hàng đợi, và loại bỏ phần tử khỏi hàng đợi.

Hướng dẫn chương trình ghi mã nguồn chi tiết trong Python:

class Queue:

    def __init__(self, N):

        self.queue = [None] * N  # Khởi tạo mảng với kích thước N

        self.N = N  # Lưu trữ kích thước của hàng đợi

        self.backIdx = -1  # Khởi tạo chỉ số phần tử đuôi của hàng đợi

    def isFullQueue(self):

        return self.backIdx == self.N - 1

    def isEmptyQueue(self):

        return self.backIdx == -1

    def enqueue(self, value):

        if self.isFullQueue():

            print("Queue is full. Cannot enqueue.")

        else:

            self.backIdx += 1

            self.queue[self.backIdx] = value

    def dequeue(self):

        if self.isEmptyQueue():

            print("Queue is empty. Cannot dequeue.")

            return None

        else:

            value = self.queue[0]

            for i in range(1, self.backIdx + 1):

                self.queue[i - 1] = self.queue[i]

            self.queue[self.backIdx] = None  # Xóa phần tử cuối cùng

            self.backIdx -= 1

            return value

    def front(self):

        if self.isEmptyQueue():

            print("Queue is empty. No front element.")

            return None

        else:

            return self.queue[0]

    def rear(self):

        if self.isEmptyQueue():

            print("Queue is empty. No rear element.")

            return None

        else:

            return self.queue[self.backIdx]

    def length(self):

        return self.backIdx + 1

    def display(self):

        if self.isEmptyQueue():

            print("Queue is empty.")

        else:

            print("Queue contents:", end=" ")

            for i in range(self.backIdx + 1):

                print(self.queue[i], end=" ")

            print()

# Khởi tạo mảng T

T = [1, 2, 3, 4, 5]

N = len(T)

# Tạo hàng đợi từ mảng T

queue = Queue(N)

for item in T:

    queue.enqueue(item)

# Hiển thị hàng đợi

queue.display()

# Ví dụ về các thao tác cơ bản

print("Dequeue:", queue.dequeue())

queue.display()

print("Enqueue 6")

queue.enqueue(6)

queue.display()

print("Front element:", queue.front())

print("Rear element:", queue.rear())

print("Queue length:", queue.length())

Ghi chú giải thích chi tiết:

Lớp Queue:

- Phương thức init: Khởi tạo hàng đợi với kích thước N và biến backIdx ban đầu là -1 để biểu diễn hàng đợi rỗng.

- Phương thức isFullQueue: Kiểm tra xem hàng đợi đã đầy chưa bằng cách so sánh backIdx với N-1.

- Phương thức isEmptyQueue: Kiểm tra xem hàng đợi có rỗng không bằng cách kiểm tra backIdx có bằng -1 hay không.

- Phương thức enqueue: Thêm một phần tử vào cuối hàng đợi nếu hàng đợi chưa đầy.

- Phương thức dequeue: Loại bỏ phần tử đầu tiên của hàng đợi nếu hàng đợi không rỗng. Các phần tử còn lại sẽ được dịch chuyển lên một vị trí.

- Phương thức front: Trả về phần tử đầu tiên của hàng đợi.

- Phương thức rear: Trả về phần tử cuối cùng của hàng đợi.

- Phương thức length: Trả về số lượng phần tử hiện có trong hàng đợi.

- Phương thức display: Hiển thị các phần tử trong hàng đợi.

 

 

 


 

CÂU HỎI HOT CÙNG CHỦ ĐỀ

Câu 1:

Em hãy nêu sự giống nhau và khác nhau giữa các hàm của ngăn xếp và hàng đợi được cài đặt bằng danh sách (kiểu list của Python).

Xem đáp án » 13/07/2024 180

Câu 2:

Khi hàng đợi Q được cài đặt bằng danh sách (kiểu list của Python), em hãy cho biết chỉ số của các phản tử tại đầu (front) và đuôi (rear). So sánh các chỉ số này với chỉ số của các phần tử tại đáy (bottom) và đỉnh (top) của ngăn xếp (cũng được cài đặt bằng danh sách). 

Xem đáp án » 13/07/2024 141

Câu 3:

Hãy giải thích vì sao lệnh dequeue(Q) lại có độ phức tạp thời gian là O(n), với n là độ dài của hàng đợi hiện thời.

Xem đáp án » 13/07/2024 137

Câu 4:

Khi hàng đợi được cài đặt bằng danh sách (kiểu list của Python), em hãy cho biết cách tính số phần tử của hàng đợi này.

Xem đáp án » 13/07/2024 132

Câu 5:

Quan sát, trao đổi, thảo luận để tìm hiểu cách biểu diễn hàng đợi bằng mảng một chiều. Em hãy trả lời các câu hỏi sau:

1. Có thể biểu diễn hàng đợi bằng mảng một chiều được không? 

2. Cần có các biến nào để thực hiện các phép toán thêm vào và lấy ra?

Xem đáp án » 13/07/2024 122

Câu 6:

Ban đầu, hàng đợi là rỗng. Em hãy cho biết giá trị của phần tử ở đầu (front) và đuôi (rear) sau khi thực hiện tuần tự các phép toán enqueue(Q,2); enqueue(Q,19); dequeue(Q), enaqueue (Q, 6); dequeue(Q); enqueue(Q, 9); enqueue(Q,1).

Xem đáp án » 13/07/2024 118

Bình luận


Bình luận
Đăng ký gói thi VIP

VIP +3 - Luyện thi tất cả các đề có trên Website trong 3 tháng

  • Được thi tất cả các đề của các lớp có trên Khoahoc.vietjack.com
  • Ngân hàng câu hỏi trắc nghiệm theo các mức độ Nhận biết, Thông hiểu, Vận dụng, Vận dụng cao.
  • Luyện chuyên sâu, rèn tốc độ với trọn bộ đề thi thử, đề minh họa, chính thức các năm.
  • Hỏi bài tập với đội ngũ chuyên môn cao của chúng tôi.

Đặt mua

VIP +6 - Luyện thi tất cả các đề có trên Website trong 6 tháng

  • Được thi tất cả các đề của các lớp có trên Khoahoc.vietjack.com
  • Ngân hàng câu hỏi trắc nghiệm theo các mức độ Nhận biết, Thông hiểu, Vận dụng, Vận dụng cao.
  • Luyện chuyên sâu, rèn tốc độ với trọn bộ đề thi thử, đề minh họa, chính thức các năm.
  • Hỏi bài tập với đội ngũ chuyên môn cao của chúng tôi.

Đặt mua

VIP +12 - Luyện thi tất cả các đề có trên Website trong 12 tháng

  • Siêu tiết kiệm - Được thi tất cả các đề của các lớp có trên Khoahoc.vietjack.com
  • Ngân hàng câu hỏi trắc nghiệm theo các mức độ Nhận biết, Thông hiểu, Vận dụng, Vận dụng cao.
  • Luyện chuyên sâu, rèn tốc độ với trọn bộ đề thi thử, đề minh họa, chính thức các năm.
  • Hỏi bài tập với đội ngũ chuyên môn cao của chúng tôi.

Đặt mua

Vietjack official store