Bài giảng Cấu trúc dữ liệu và giải thuật trong C++ - Bài 9: Cấu trúc dữ liệu hàng đợi
Số trang: 12
Loại file: pdf
Dung lượng: 508.49 KB
Lượt xem: 12
Lượt tải: 0
Xem trước 2 trang đầu tiên của tài liệu này:
Thông tin tài liệu:
Bài giảng "Cấu trúc dữ liệu và giải thuật trong C++ - Bài 9: Cấu trúc dữ liệu hàng đợi" cung cấp cho người học các kiến thức: Danh sách kiểu hàng đợi (Queue), cấu trúc dữ liệu trừu tượng queue, cài đặt queue bằng mảng,.... Mời các bạn cung cấp cho người học các kiến thức.
Nội dung trích xuất từ tài liệu:
Bài giảng Cấu trúc dữ liệu và giải thuật trong C++ - Bài 9: Cấu trúc dữ liệu hàng đợiBài 9. Cấu trúc dữ liệu hàng đợiDanh sách kiểu Hàng đợi (Queue) Queue là cách tổ chức lưu trữ các đối tượng dưới dạng một danh sách tuyến tính mà việc bổ sung đối tượng được thực hiện ở đầu danh sách và việc lấy đối tượng ra được thực hiện ở cuối của danh sách. Queue còn được gọi là danh sách kiểu FIFO (First In First Out - vào trước ra trước) Cấu trúc dữ liệu trừu tượng Queue (The Queue ADT) Queue ADT lưu trữ các đối Các phép toán bổ trợ tượng bất kỳ • front(): trả lại phần tử đầu của Thêm vào và xóa đi (lấy ra) queue nhưng không xóa nó đi theo kiểu FIFO • size(): trả lại số phần tử hiện Thêm vào thực hiện ở cuối đang được lưu trữ trong queue của queue và lấy ra thực hiện ở đầu queue • isEmpty(): trả lại giá trị kiểu boolen để xác định có phần Các phép toán chính thực tử được lưu trữ trong queue hiện trên queue: không? • enqueue(Object o): bổ sung Ngoại lệ: thực hiện dequeue một phần tử o vào cuối của hoặc enqueue trong khi queue. queue rỗng hoặc đầy • dequeue(Object &o): Xóa đi phần tử đầu của queue ta cần phải chuyển đến ngoại lệMột số ứng dụng của queueCác ứng dụng trực tiếp - Danh sách hàng đợi - Truy nhập các nguồn dùng chung (ví dụ máy in trong mạng cục bộ) - Đa lập trìnhCác ứng dụng không trực tiếp - Cấu trúc dữ liệu hỗ trợ cho các thuật toán - Làm thành phần của các cấu trúc dữ liệu khácCài đặt queue bằng mảng Sử dụng một mảng kiểu vòng có kích thước N Sử dụng 2 biến lưu trữ chỉ số của phần tử trước và phần tử sau: f lưu chỉ số phần tử trước r lưu trữ chỉ số phần tử chuẩn bị được đưa vào Vị trí r của mảng là rỗng Cấu hình bình thường Cấu hình vòng lạiCác phép toán trên queue Chúng ta sử dụng phép toán modulo để xác định số phần tử còn lại của queueCác phép toán trên queue (tiếp) Phép toán ensqueue dẫn đến ngoại lệ khi mảng đầy Algorthim enqueue(Object o) if size()=N-1 then return 0 else Q[r]←o r←(r+1) mod N return 1;Các phép toán trên queue (tiếp) Phép toán dequeue dẫn đến ngoại lệ khi mảng rỗng Algorthim dequeue(Object &o) if isEmpty() then return 0 else o←Q[f] f←(f+1) mod N return 1Phát triển queue dựa trên mảng Khi thêm phần tử vào mảng, có thể xảy ra ngoại lệ. Để tránh điều đó ta có thể sử dụng một mảng có kích thước lớn hơn Tương tự phát triển stack dựa trên mảng Thời gian thực hiện của thuật toán là: - O(n) với chiến lược gia tăng - O(1) với chiến lược gấp đôiCài đặt queue bằng C++ #define N //const integer ADT queue không phù template hợp khi cài đặt bằng C++ class Queue{ (trên DOS) vì nó yêu cầu private: định nghĩa lớp có cho Object Q[N]; phép dẫn đến ngoại lệ. int f, r; Tuy nhiên chúng ta vẫn public: có thể sử dụng C++ để cài đặt queue Queue(); int isEmpty(); int size(); Object front(); int enqueue(Object o); int dequeue(Object &o); };Cài đặt queue bằng C++ int Queue::enqueue(Object o){ if (size()=N-1) return 0; else{ Q[r]=o; r =(r+1)%N; return 1; } }Bài tập 1. Cài đặt lớp Queue mẫu bằng cách sử dụng mảng 2. Cài đặt Queue mẫu bằng cách sử dụng danh sách liên kết 3. Cài đặt lớp ứng dụng sử dụng lớp Queue để tổ chức lưu trữ các đối tượng là các số nguyên. Lớp có các chức năng: 1. Thêm vào Queue 1 phần tử 2. Lấy phần tử ra khỏi queue và hiển thị lên màn hình 3. Cho biết số phần tử hiện có của Queue 4. Cho biết Queue rỗng hay đầy ...
Nội dung trích xuất từ tài liệu:
Bài giảng Cấu trúc dữ liệu và giải thuật trong C++ - Bài 9: Cấu trúc dữ liệu hàng đợiBài 9. Cấu trúc dữ liệu hàng đợiDanh sách kiểu Hàng đợi (Queue) Queue là cách tổ chức lưu trữ các đối tượng dưới dạng một danh sách tuyến tính mà việc bổ sung đối tượng được thực hiện ở đầu danh sách và việc lấy đối tượng ra được thực hiện ở cuối của danh sách. Queue còn được gọi là danh sách kiểu FIFO (First In First Out - vào trước ra trước) Cấu trúc dữ liệu trừu tượng Queue (The Queue ADT) Queue ADT lưu trữ các đối Các phép toán bổ trợ tượng bất kỳ • front(): trả lại phần tử đầu của Thêm vào và xóa đi (lấy ra) queue nhưng không xóa nó đi theo kiểu FIFO • size(): trả lại số phần tử hiện Thêm vào thực hiện ở cuối đang được lưu trữ trong queue của queue và lấy ra thực hiện ở đầu queue • isEmpty(): trả lại giá trị kiểu boolen để xác định có phần Các phép toán chính thực tử được lưu trữ trong queue hiện trên queue: không? • enqueue(Object o): bổ sung Ngoại lệ: thực hiện dequeue một phần tử o vào cuối của hoặc enqueue trong khi queue. queue rỗng hoặc đầy • dequeue(Object &o): Xóa đi phần tử đầu của queue ta cần phải chuyển đến ngoại lệMột số ứng dụng của queueCác ứng dụng trực tiếp - Danh sách hàng đợi - Truy nhập các nguồn dùng chung (ví dụ máy in trong mạng cục bộ) - Đa lập trìnhCác ứng dụng không trực tiếp - Cấu trúc dữ liệu hỗ trợ cho các thuật toán - Làm thành phần của các cấu trúc dữ liệu khácCài đặt queue bằng mảng Sử dụng một mảng kiểu vòng có kích thước N Sử dụng 2 biến lưu trữ chỉ số của phần tử trước và phần tử sau: f lưu chỉ số phần tử trước r lưu trữ chỉ số phần tử chuẩn bị được đưa vào Vị trí r của mảng là rỗng Cấu hình bình thường Cấu hình vòng lạiCác phép toán trên queue Chúng ta sử dụng phép toán modulo để xác định số phần tử còn lại của queueCác phép toán trên queue (tiếp) Phép toán ensqueue dẫn đến ngoại lệ khi mảng đầy Algorthim enqueue(Object o) if size()=N-1 then return 0 else Q[r]←o r←(r+1) mod N return 1;Các phép toán trên queue (tiếp) Phép toán dequeue dẫn đến ngoại lệ khi mảng rỗng Algorthim dequeue(Object &o) if isEmpty() then return 0 else o←Q[f] f←(f+1) mod N return 1Phát triển queue dựa trên mảng Khi thêm phần tử vào mảng, có thể xảy ra ngoại lệ. Để tránh điều đó ta có thể sử dụng một mảng có kích thước lớn hơn Tương tự phát triển stack dựa trên mảng Thời gian thực hiện của thuật toán là: - O(n) với chiến lược gia tăng - O(1) với chiến lược gấp đôiCài đặt queue bằng C++ #define N //const integer ADT queue không phù template hợp khi cài đặt bằng C++ class Queue{ (trên DOS) vì nó yêu cầu private: định nghĩa lớp có cho Object Q[N]; phép dẫn đến ngoại lệ. int f, r; Tuy nhiên chúng ta vẫn public: có thể sử dụng C++ để cài đặt queue Queue(); int isEmpty(); int size(); Object front(); int enqueue(Object o); int dequeue(Object &o); };Cài đặt queue bằng C++ int Queue::enqueue(Object o){ if (size()=N-1) return 0; else{ Q[r]=o; r =(r+1)%N; return 1; } }Bài tập 1. Cài đặt lớp Queue mẫu bằng cách sử dụng mảng 2. Cài đặt Queue mẫu bằng cách sử dụng danh sách liên kết 3. Cài đặt lớp ứng dụng sử dụng lớp Queue để tổ chức lưu trữ các đối tượng là các số nguyên. Lớp có các chức năng: 1. Thêm vào Queue 1 phần tử 2. Lấy phần tử ra khỏi queue và hiển thị lên màn hình 3. Cho biết số phần tử hiện có của Queue 4. Cho biết Queue rỗng hay đầy ...
Tìm kiếm theo từ khóa liên quan:
Bài giảng Cấu trúc dữ liệu Cấu trúc dữ liệu và giải thuật Lập trình C++ Kỹ thuật lập trình Ngôn ngữ lập trình Cấu trúc dữ liệu hàng đợiGợi ý tài liệu liên quan:
-
Đề cương chi tiết học phần Cấu trúc dữ liệu và giải thuật (Data structures and algorithms)
10 trang 305 0 0 -
Giáo trình Lập trình hướng đối tượng: Phần 2
154 trang 259 0 0 -
Kỹ thuật lập trình trên Visual Basic 2005
148 trang 250 0 0 -
Bài thuyết trình Ngôn ngữ lập trình: Hệ điều hành Window Mobile
30 trang 249 0 0 -
Giáo trình Lập trình cơ bản với C++: Phần 1
77 trang 229 0 0 -
Bài giảng Một số hướng nghiên cứu và ứng dụng - Lê Thanh Hương
13 trang 211 0 0 -
Giáo án Tin học lớp 11 (Trọn bộ cả năm)
125 trang 202 1 0 -
NGÂN HÀNG CÂU HỎI TRẮC NGHIỆM THIẾT KẾ WEB
8 trang 190 0 0 -
Giới thiệu môn học Ngôn ngữ lập trình C++
5 trang 181 0 0 -
Bài tập lập trình Windows dùng C# - Bài thực hành
13 trang 168 0 0