Chương 2: Stack
lượt xem 11
download
Tham khảo bài thuyết trình 'chương 2: stack', công nghệ thông tin, cơ sở dữ liệu phục vụ nhu cầu học tập, nghiên cứu và làm việc hiệu quả
Bình luận(0) Đăng nhập để gửi bình luận!
Nội dung Text: Chương 2: Stack
- CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT Chương 2: Stack
- Mô tả stack Một stack là một cấu trúc dữ liệu mà việc thêm vào và loại bỏ được thực hiện tại một đầu (gọi là đỉnh – top của stack). Là một dạng vào sau ra trước – LIFO (Last In First Out) 2 Chương 2: Stack
- Ví dụ về stack Stack rỗng: Đẩy (push) Q vào: Q Đẩy A vào: A Q Lấy (pop) ra một => được A: A Q Lấy ra một => được Q và stack rỗng: Q 3 Chương 2: Stack
- Ứng dụng: Đảo ngược danh sách Yêu cầu: Đảo ngược một danh sách nhập vào Giải thuật: 1. Lặp lại n lần 1.1. Nhập vào một giá trị 1.2. Đẩy nó vào stack 2. Lặp khi stack chưa rỗng 2.1. Lấy một giá trị từ stack 2.2. In ra 4 Chương 2: Stack
- Đảo ngược danh sách – Ví dụ Cần nhập 4 số vào Nhập 1 Nhập 5 Nhập 7 Nhập 3 Ban đầu 3 7 7 5 5 5 1 1 1 1 Stack đã rỗng Lấy ra => 3 Lấy ra => 7 Lấy ra => 5 Lấy ra => 1 Ngừng 3 7 7 5 5 5 1 1 1 1 5 Chương 2: Stack
- Đảo ngược danh sách – Mã C++ #include sử dụng STL using namespace std; (Standard Template Library) int main( ) { khai báo một stack có kiểu dữ liệu int n; của các phân tử bên trong là double double item; stack numbers; cout > n; for (int i = 0; i < n; i++) { đẩy một số vào trong stack cin >> item; numbers.push(item); kiểm tra xem stack có khác rỗng không } while (!numbers.empty( )) { lấy giá trị trên đỉnh của stack ra, cout
- Kiểu trừu tượng (abstract data type) ĐN1: Một kiểu (type) một tập hợp mỗi thành phần của tập hợp này là các giá tr ị (value) Ví dụ: int, float, char là các kiểu cơ bản ĐN2: Một dãy của kiểu T có chiều dài bằng 0 là rỗng có chiều dài n (n>=1): bộ thứ tự (Sn-1, t) Sn-1: dãy có chiều dài n-1 thu ộc ki ểu T t là một giá trị thuộc kiểu T. 7 Chương 2: Stack
- Stack trừu tượng Một stack kiểu T: Một dãy hữu hạn kiểu T Một số tác vụ: 1. Khởi tạo stack rỗng (create) 2. Kiểm tra rỗng (empty) 3. Đẩy một giá trị vào trên đỉnh của stack (push) 4. Bỏ giá trị đang có trên đỉnh của stack (pop) 5. Lấy giá trị trên đỉnh của stack, stack không đổi ( top) 8 Chương 2: Stack
- Thiết kế stack enum Error_code {fail, success, overflow, underflow}; template class Stack { public: Stack(); //constructor //kiểm tra rỗng bool empty() const; //đẩy item vào Error_code push(const Entry &item); //bỏ phần tử trên đỉnh Error_code pop(); //lấy giá trị trên đỉnh Error_code top(Entry &item); //khai báo một số phương thức cần thiết khác private: //khai báo dữ liệu và hàm phụ trợ chỗ này }; 9 Chương 2: Stack
- Thiết kế các phương thức template bool Stack::empty() const; Pre: Không có Post: Trả về giá trị true nếu stack hiện tại là rỗng, ngược lại thì trả về false template Error_code Stack::push(const Entry &item); Pre: Không có Post: Nếu stack hiện tại không đầy, item sẽ được thêm vào đỉnh của stack. Ngược lại trả về giá trị overflow của kiểu Error_code và stack không đổi. template Error_code Stack::pop() const; Pre: Không có Post: Nếu stack hiện tại không rỗng, đỉnh của stack hiện tại sẽ bị hủy bỏ. Ngược lại trả về giá trị underflow của kiểu Error_code và stack không đổi. template Error_code Stack::top(Entry &item) const; Pre: Không có Post: Nếu stack hiện tại không rỗng, đỉnh của stack hiện tại sẽ được chép vào tham biến item. Ngược lại trả về giá trị fail của kiểu Error_code. 10 Chương 2: Stack
- Hiện thực stack liên tục 11 Chương 2: Stack
- Khai báo stack liên tục const int maxstack = 10; //small number for testing template class Stack { public: Stack( ); bool empty( ) const; Error_code pop( ); Error_code top(Entry &item) const; Error_code push(const Entry &item); private: int count; Entry entry[maxstack]; }; 12 Chương 2: Stack
- Đẩy một phần tử vào stack Giải thuật: 1. Nếu còn chỗ trống trong stack 1.1. Tăng vị trí đỉnh lên 1 1.2. Chứa giá trị vào vị trí đỉnh của stack 1.3. Tăng số phần tử lên 1 7 top 5 count=3 count=2 1 13 Chương 2: Stack
- Bỏ phần tử trên đỉnh stack Giải thuật: 1. Nếu còn phần tử trong stack 1.1. Giảm vị trí đỉnh đi 1 1.2. Giảm số phần tử đi 1 top 7 5 count=2 count=3 1 14 Chương 2: Stack
- Thêm/Bỏ phần tử - Mã C++ template Error_code Stack:: push(const Entry &item) { if (count >= maxstack) return overflow; else entry[count++] = item; return success; } template Error_code Stack:: pop() { if (count == 0) return underflow; else count--; return success; } 15 Chương 2: Stack
- Lấy giá trị trên đỉnh stack Giải thuật: 1. Nếu còn phần tử trong stack 1.1. Trả về giá trị tại vị trí đỉnh Mã C++: template Error_code Stack:: top(Entry &item) { if (count == 0) return underflow; else item = entry[count - 1]; return success; } 16 Chương 2: Stack
- Reverse Polish Calculator Mô tả bài toán: Các toán hạng được đọc vào trước và đẩy vào stack Khi đọc vào toán tử, lấy hai toán h ạng ra t ừ stack, tính toán với toán tử này, rồi đẩy kết quả vào stack Thiết kế phần mềm: Cần một stack để chứa toán hạng Cần hàm get_command để nhận lệnh từ người dùng Cần hàm do_command để thực hiện lệnh 17 Chương 2: Stack
- Reverse Polish Calculator – Thiết kế chức năng Tập lệnh: ‘?’: đọc một giá trị rồi đẩy vào stack Toán tử ‘+’, ‘-’, ‘*’, ‘/’: lấy 2 giá trị trong stack, tính toán và đẩy kết quả vào stack Toán tử ‘=’: in đỉnh của stack ra ‘q’: kết thúc chương trình 18 Chương 2: Stack
- Reverse Polish Calculator – Ví dụ Tính toán biểu thức: 3 5 + 2 * = 5 5 8 3 3 3 Toán tử ? Toán tử ? Ban đầu Toán tử + Đẩy 8 vào Nhập vào 3 Nhập vào 5 Lấy ra 5 và 3 Tính 3 + 5 => 8 2 2 8 8 16 16 Toán tử ? Toán tử * Toán tử = Đẩy vào 16 Nhập vào 2 Lấy ra 2 và 8 In ra 16 Tính 8 * 2 => 16 19 Chương 2: Stack
- Reverse Polish Calculator – Hàm get_command char get command( ) { char command; bool waiting = true; cout > command; command = tolower(command); if (command == ‘?’ || command == ‘=‘ || command == ‘+’ || command == ‘−’|| command == ‘*’ || command == ‘/’ || command == ‘q’) waiting = false; else { cout
CÓ THỂ BẠN MUỐN DOWNLOAD
-
Ngôn ngữ lập trình C - Chương 7 - Bài 2. Stack
10 p | 224 | 43
-
Cấu trúc dữ liệu và giải thuật - chương 10
51 p | 258 | 40
-
Cấu trúc dữ liệu và giải thuật - chương 2
24 p | 239 | 21
-
Bài Giảng Hệ Điều Hành-Chương 2: Quá trình
44 p | 77 | 20
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 3.2 - Trần Minh Thái
58 p | 126 | 14
-
Giáo trình kỹ thuật đồ họa - Chương 2
16 p | 143 | 12
-
Bài giảng Kiến trúc máy tính: Chương 3.2 - Võ Tấn Phương
63 p | 94 | 12
-
Bài giảng Nguyên lý ngôn ngữ lập trình - Chương 2: Một trình biên dịch đơn giản
37 p | 64 | 11
-
Lý thuyết hệ điều hành - Chương 2
18 p | 118 | 10
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 2 - ĐH Bách khoa TP. HCM
25 p | 83 | 7
-
Bài giảng Cấu trúc dữ liệu và giải thuật (Data Structures and Algorithms): Chương 2 - GV. Ngô Công Thắng
19 p | 17 | 6
-
Phương pháp bảo vệ dữ liệu: Phần 2
144 p | 31 | 6
-
Bài giảng Nhập môn chương trình dịch: Chương 2 - Hoàng Anh Việt
59 p | 64 | 4
-
Bài giảng Kỹ thuật lập trình (Programming technique): Chương 4.2 - Vũ Đức Vượng
127 p | 25 | 4
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 2
48 p | 22 | 3
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 2.2 - TS. Nguyễn Thị Kim Thoa
13 p | 16 | 3
-
Bài giảng Cấu trúc dữ liệu và giải thuật - Chương 2: Mảng & danh sách
16 p | 54 | 2
Chịu trách nhiệm nội dung:
Nguyễn Công Hà - Giám đốc Công ty TNHH TÀI LIỆU TRỰC TUYẾN VI NA
LIÊN HỆ
Địa chỉ: P402, 54A Nơ Trang Long, Phường 14, Q.Bình Thạnh, TP.HCM
Hotline: 093 303 0098
Email: support@tailieu.vn