Câu hỏi:
13/07/2024 118Ban đầ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).
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).
Quảng cáo
Trả lời:
Để xác định 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 trên hàng đợi (queue), ta sẽ theo dõi từng phép toán một cách chi tiết. Giả sử hàng đợi ban đầu có dung lượng đủ lớn để chứa tất cả các phần tử được thêm vào mà không cần phải xử lý trường hợp tràn (overflow).
Ban đầu, hàng đợi là rỗng:
front = 0
rear = -1
size = 0
Các bước thực hiện tuần tự các phép toán như sau:
1. enqueue(Q, 2)
Thêm 2 vào cuối hàng đợi.
rear tăng lên 0.
size tăng lên 1.
queue = [2]
front = 0
rear = 0
2. enqueue(Q, 19)
Thêm 19 vào cuối hàng đợi.
rear tăng lên 1.
size tăng lên 2.
queue = [2, 19]
front = 0
rear = 1
3. dequeue(Q)
Lấy 2 ra từ đầu hàng đợi.
front tăng lên 1.
size giảm xuống 1.
queue = [2, 19] (phần tử tại front không còn được sử dụng)
front = 1
rear = 1
4. enqueue(Q, 6)
Thêm 6 vào cuối hàng đợi.
rear tăng lên 2.
size tăng lên 2.
queue = [2, 19, 6]
front = 1
rear = 2
5. dequeue(Q)
Lấy 19 ra từ đầu hàng đợi.
front tăng lên 2.
size giảm xuống 1.
queue = [2, 19, 6] (phần tử tại front không còn được sử dụng)
front = 2
rear = 2
6. enqueue(Q, 9)
Thêm 9 vào cuối hàng đợi.
rear tăng lên 3.
size tăng lên 2.
queue = [2, 19, 6, 9]
front = 2
rear = 3
7. enqueue(Q, 1)
Thêm 1 vào cuối hàng đợi.
rear tăng lên 4.
size tăng lên 3.
queue = [2, 19, 6, 9, 1]
front = 2
rear = 4
- Sau khi thực hiện tuần tự các phép toán, trạng thái của hàng đợi sẽ như sau:
queue = [2, 19, 6, 9, 1]
front = 2 (phần tử ở đầu hàng đợi là 6)
rear = 4 (phần tử ở cuối hàng đợi là 1)
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).
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).
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.
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.
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?
Đề thi học kì 1 Tin học 12 Kết nối tri thức có đáp án- Đề 1
263 câu Trắc nghiệm tổng hợp ôn thi tốt nghiệp THPT môn Tin học Chủ đề F. Giải quyết vấn đề với sự trợ giúp của máy tính có đáp án
15 câu Trắc nghiệm Tin học 12 Kết nối tri thức Bài 7 có đáp án
15 câu Trắc nghiệm Tin học 12 Kết nối tri thức Bài 10 có đáp án
Đề thi học kì 1 Tin học 12 Kết nối tri thức có đáp án- Đề 2
15 câu Trắc nghiệm Tin học 12 Kết nối tri thức Bài 8 có đáp án
Đề thi học kì 1 Tin học 12 Kết nối tri thức có đáp án- Đề 3
15 câu Trắc nghiệm Tin học 12 Kết nối tri thức Bài 9 có đáp án
về câu hỏi!