Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 4 - ĐH Bách khoa TP. HCM
lượt xem 12
download
Bài giảng "Cấu trúc dữ liệu và giải thuật - Chương 4: Stack và Queue liên kết" cung cấp cho người học các kiến thức: Con trỏ, biểu diễn con trỏ bằng C++, sử dụng con trỏ trong C++, gán con trỏ trong C++, thiết kế node liên kết, thiết kế node liên kết bằng C++, stack liên kết, đảm bảo an toàn con trỏ trong C++, sao chép vùng dữ liệu – Mã C++,... Mời các bạn cùng tham khảo nội dung chi tiết.
Bình luận(0) Đăng nhập để gửi bình luận!
Nội dung Text: Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 4 - ĐH Bách khoa TP. HCM
- A C B CẤU TRÚC DỮ LIỆU VÀ F GIẢI THUẬT (501040) D E G Chương 4: Stack và Queue liên K kết H
- Con trỏ ĐH Bách Khoa Tp.HCM Khoa Công nghệ Thông tin Chương 4: Stack và Queue liên kết 2
- Biểu diễn con trỏ bằng C++ Khai báo biến: Item * item_ptr1, * item_ptr2; Tạo mới đối tượng: item_ptr1 = new Item; Hủy bỏ đối tượng: delete item_ptr1; Sử dụng: *item_ptr1 = 1378; cout StudentID; Con trỏ NULL: item_ptr2 = NULL; ĐH Bách Khoa Tp.HCM Khoa Công nghệ Thông tin Chương 4: Stack và Queue liên kết 3
- Sử dụng con trỏ trong C++ Địa chỉ của biến: Biến: int_ptr = &x; Array: arr_ptr = an_array; Dynamic array: Trong C++, array có thể được quản lý như một con trỏ và ngược lại Ví dụ: int arr[3] = {0, 1, 2, 3}; int *arr_ptr = arr; //in ra 0 – 1 – 2 cout
- Gán con trỏ trong C++ Gán nội dung: bình thường Gán con trỏ: nguy hiểm ĐH Bách Khoa Tp.HCM Khoa Công nghệ Thông tin Chương 4: Stack và Queue liên kết 5
- Thiết kế node liên kết Cần: Dữ liệu Con trỏ để trỏ đến node sau Constructor ĐH Bách Khoa Tp.HCM Khoa Công nghệ Thông tin Chương 4: Stack và Queue liên kết 6
- Thiết kế node liên kết bằng C++ template struct Node { Entry entry; // data members Node *next; Node( ); // constructors Node(Entry item, Node *add on = NULL); }; ĐH Bách Khoa Tp.HCM Khoa Công nghệ Thông tin Chương 4: Stack và Queue liên kết 7
- Ví dụ với node liên kết Node first_node(‘a’); Node *p0 = &first_node; Node *p1 = new Node(‘b’); p0->next = p1; Node *p2 = new Node(‘c’, p0); p1->next = p2; p1 p2 first_node p0 a b c ĐH Bách Khoa Tp.HCM Khoa Công nghệ Thông tin Chương 4: Stack và Queue liên kết 8
- Stack liên kết ĐH Bách Khoa Tp.HCM Khoa Công nghệ Thông tin Chương 4: Stack và Queue liên kết 9
- Khai báo stack liên kết template class Stack { public: Stack( ); bool empty( ) const; Error_code push(const Entry &item); Error_code pop( ); Error_code top(Entry &item) const; Stack(const Stack ©); ~Stack(); void operator=(const Stack ©); protected: Node *top_node; }; ĐH Bách Khoa Tp.HCM Khoa Công nghệ Thông tin Chương 4: Stack và Queue liên kết 10
- Thêm vào một stack liên kết Giải thuật 1. Tạo ra một node mới với giá trị cần thêm vào 2. Trỏ nó đến đỉnh hiện tại của stack 3. Trỏ đỉnh của stack vào node mới new_top new node top_node old top middle last ĐH Bách Khoa Tp.HCM Khoa Công nghệ Thông tin Chương 4: Stack và Queue liên kết 11
- Bỏ đỉnh của một stack liên kết Giải thuật: 1. Gán một con trỏ để giữ đỉnh của stack 2. Trỏ đỉnh của stack vào node ngay sau đỉnh hiện tại 3. Xóa node cũ đi top_node old top middle old last old_top ĐH Bách Khoa Tp.HCM Khoa Công nghệ Thông tin Chương 4: Stack và Queue liên kết 12
- Thêm/Bỏ đỉnh của một stack liên kết – Mã C++ template Error_code push(const Entry &item) { Node *new_top = new Node(item, top_node); if (new_top == NULL) return overflow; top_node = new_top; } template Error_code pop( ) { Node *old_top = top_node; if (top_node == NULL) return underflow; top_node = old_top->next; delete old_top; } ĐH Bách Khoa Tp.HCM Khoa Công nghệ Thông tin Chương 4: Stack và Queue liên kết 13
- Sự không an toàn con trỏ trong C++ Kết thúc biến stack nhưng bộ nhớ còn lại: delete stack0; stack0 top middle last Gán hai stack: cả hai dùng chung một vùng dữ liệu stack2 = stack1; stack2 top middle last stack1 top middle last ĐH Bách Khoa Tp.HCM Khoa Công nghệ Thông tin Chương 4: Stack và Queue liên kết 14
- Đảm bảo an toàn con trỏ trong C++ Destructor: Sẽ được gọi ngay trước khi đối tượng kết thúc thời gian sống Dùng xóa hết vùng dữ liệu Copy constructor: Sẽ được gọi khi khởi tạo biến lúc khai báo, hoặc truyền dữ liệu bằng tham trị Sao chép nguồn thành một vùng dữ liệu mới Assignment operator: Sẽ được gọi khi gán đối tượng này vào đối tượng khác Xóa vùng dữ liệu của đích và đồng thời sao chép nguồn thành một vùng dữ liệu mới ĐH Bách Khoa Tp.HCM Khoa Công nghệ Thông tin Chương 4: Stack và Queue liên kết 15
- Xóa vùng dữ liệu đang có Giải thuật: 1. Trong khi stack chưa rỗng 1.1. Bỏ đỉnh của stack Mã C++: while (!empty()) pop(); ĐH Bách Khoa Tp.HCM Khoa Công nghệ Thông tin Chương 4: Stack và Queue liên kết 16
- Sao chép vùng dữ liệu Giải thuật: 1. Tạo một đỉnh của danh sách mới với dữ liệu của đỉnh nguồn 2. Giữ một con trỏ đuôi chỉ vào cuối danh sách mới 2. Duyệt qua danh sách nguồn 2.1. Tạo một node mới với dữ liệu từ node nguồn hiện tại 2.2. Nối vào cuối danh sách mới 2.3. Con trỏ đuôi là node mới ĐH Bách Khoa Tp.HCM Khoa Công nghệ Thông tin Chương 4: Stack và Queue liên kết 17
- Sao chép vùng dữ liệu – Ví dụ copy.top_node a b c copy_node new_copy new_top a b c ĐH Bách Khoa Tp.HCM Khoa Công nghệ Thông tin Chương 4: Stack và Queue liên kết 18
- Sao chép vùng dữ liệu – Mã C++ Node *new_top, *new_copy, *copy_node = copy.top_node; if (copy_node == NULL) new_top = NULL; else { // Sao chép vùng dữ liệu thành danh sách mới new_copy = new_top = new Node(copy_node->entry); while (copy_node->next != NULL) { copy_node = copy_node->next; new_copy->next = new Node(copy_node->entry); new_copy = new_copy->next; } } clear(); //xóa rỗng dữ liệu hiện tại trước top_node = new_top; // thay thế dữ liệu bằng danh sách mới. ĐH Bách Khoa Tp.HCM Khoa Công nghệ Thông tin Chương 4: Stack và Queue liên kết 19
- Queue liên kết Thiết kế: Dùng hai con trỏ chỉ đến đầu và cuối của danh sách front dữ liệu (front và rear) rear front middle last Khởi tạo rỗng: gán cả front và rear về NULL front rear ĐH Bách Khoa Tp.HCM Khoa Công nghệ Thông tin Chương 4: Stack và Queue liên kết 20
CÓ THỂ BẠN MUỐN DOWNLOAD
-
Bài giảng Cấu trúc dữ liệu & thuật toán: Chương 3 - Nguyễn Đức Nghĩa
0 p | 491 | 166
-
Bài giảng Cấu trúc dữ liệu cơ bản và giải thuật - Chương 1
9 p | 258 | 29
-
Bài giảng Cấu trúc dữ liệu - Bài 1:Tổng quan về cấu trúc dữ liệu và giải thuật
47 p | 179 | 17
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 3 - Đỗ Bích Diệp
28 p | 119 | 10
-
Bài giảng Cấu trúc dữ liệu: Chương 10 - Nguyễn Xuân Vinh
31 p | 95 | 10
-
Bài giảng Cấu trúc dữ liệu 1: Chương 1 - Lương Trần Hy Hiến
7 p | 162 | 9
-
Bài giảng Cấu trúc dữ liệu và giải thuật trong C++ - Bài 8: Cấu trúc dữ liệu ngăn xếp
28 p | 81 | 9
-
Bài giảng Cấu trúc dữ liệu giải thuật: Các kiểu dữ liệu trừu tượng cơ bản - Cấu trúc dữ liệu tuyến tính
92 p | 117 | 9
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Cấu trúc dữ liệu cây đỏ đen - Bùi Tiến Lên
25 p | 88 | 8
-
Bài giảng Cấu trúc dữ liệu và giải thuật – Bài 17: Cấu trúc dữ liệu dạng cây
21 p | 77 | 8
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Các cấu trúc dữ liệu
193 p | 62 | 7
-
Bài giảng Cấu trúc dữ liệu: Chương Giới thiệu - Nguyễn Xuân Vinh
8 p | 112 | 7
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 1 - Trần Minh Thái (2016)
62 p | 94 | 6
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 1 - Trần Minh Thái (Trường Đại học Hồng Bàng )
62 p | 173 | 6
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 1 – Trần Minh Thái (2017)
67 p | 107 | 4
-
Bài giảng Cấu trúc dữ liệu và giải thuật – Chương 1: Tổng quan về giải thuật và cấu trúc dữ liệu
10 p | 70 | 4
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Các khái niệm cơ bản
23 p | 48 | 3
-
Bài giảng Cấu trúc dữ liệu giải thuật: Cấu trúc dữ liệu
17 p | 53 | 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