Câu hỏi:
13/07/2024 226Em 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).
Hot: 500+ Đề thi thử tốt nghiệp THPT các môn, ĐGNL các trường ĐH... file word có đáp án (2025).
Quảng cáo
Trả lời:
So sánh giữa các hàm của ngăn xếp (stack) và hàng đợi (queue) được cài đặt bằng danh sách (list) của Python:
* Sự giống nhau
1. Dữ liệu cơ bản:
- Cả hai đều sử dụng danh sách (list) của Python để lưu trữ các phần tử.
2. Khởi tạo:
- Cả hai đều cần một phương thức khởi tạo (__init__) để tạo một danh sách trống.
3. Kiểm tra rỗng:
- Cả hai đều có một phương thức để kiểm tra xem cấu trúc dữ liệu có rỗng hay không (is_empty).
* Sự khác nhau:
1. Thêm phần tử:
- Ngăn xếp (stack):
+ Hàm push thêm một phần tử vào cuối danh sách (đỉnh ngăn xếp).
+ self.stack.append(item)
- Hàng đợi (queue):
+ Hàm enqueue thêm một phần tử vào cuối danh sách (đuôi hàng đợi).
+ self.queue.append(item)
- Lấy phần tử:
+ Ngăn xếp (stack):
+ Hàm pop lấy phần tử cuối cùng của danh sách (đỉnh ngăn xếp) và trả về phần tử đó.
+ return self.stack.pop()
+ Hàng đợi (queue):
+ Hàm dequeue lấy phần tử đầu tiên của danh sách (đầu hàng đợi) và trả về phần tử đó.
+ return self.queue.pop(0)
- Lấy phần tử nhưng không xóa:
+ Ngăn xếp (stack):
Hàm top trả về phần tử cuối cùng của danh sách (đỉnh ngăn xếp) mà không xóa nó.
return self.stack[-1]
Hàm bottom trả về phần tử đầu tiên của danh sách (đáy ngăn xếp) mà không xóa nó.
return self.stack[0]
+ Hàng đợi (queue):
Hàm front trả về phần tử đầu tiên của danh sách (đầu hàng đợi) mà không xóa nó.
return self.queue[0]
Hàm rear trả về phần tử cuối cùng của danh sách (đuôi hàng đợi) mà không xóa nó.
return self.queue[-1]
Đã bán 730
Đã bán 1,1k
Đã bán 1,5k
Đã bán 1,4k
CÂU HỎI HOT CÙNG CHỦ ĐỀ
Câu 1:
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 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 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 6:
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?
15 câu Trắc nghiệm Tin học 12 Kết nối tri thức Bài 19 có đáp án
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 18 có đáp án
15 câu Trắc nghiệm Tin học 12 Kết nối tri thức Bài 16 có đáp án
15 câu Trắc nghiệm Tin học 12 Kết nối tri thức Bài 21 có đáp án
Trắc nghiệm Tin học 12 KNTT Bài 17: Các mức ưu tiên của bộ chọn
15 câu Trắc nghiệm Tin học 12 Cánh diều Giới thiệu trí tuệ nhân tạo có đáp án
15 câu Trắc nghiệm Tin học 12 Kết nối tri thức Bài 20 có đáp án
Hãy Đăng nhập hoặc Tạo tài khoản để gửi bình luận