Cấu trúc dữ liệu và giải thuật - chương 2
Số trang: 24
Loại file: ppt
Dung lượng: 374.00 KB
Lượt xem: 11
Lượt tải: 0
Xem trước 3 trang đầu tiên của tài liệu này:
Thông tin tài liệu:
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 với tài liệu này các bạn sinh viên CNTT có thể nắm vững các kiến thức về stack.
Nội dung trích xuất từ tài liệu:
Cấu trúc dữ liệu và giải thuật - chương 2 A CCẤU TRÚC DỮ LIỆU VÀ B F GIẢI THUẬT (501040) D E G Chương 2: Stack K H 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 Khoa Công nghệ Thông tinĐH Bách Khoa Tp.HCM Ví dụ về stack Stack rỗng: Q Đẩy (push) Q vào: A Q Đẩy A vào: A Lấy (pop) ra một => được A: Q Lấy ra một => được Q và stack rỗng: Q 3 Chương 2: Stack Khoa Công nghệ Thông tinĐH Bách Khoa Tp.HCM Ứ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 Khoa Công nghệ Thông tinĐH Bách Khoa Tp.HCM Đả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 Khoa Công nghệ Thông tinĐH Bách Khoa Tp.HCM Đả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; đẩy một số vào trong stack for (int i = 0; i < n; i++) { cin >> item; kiểm tra xem stack có khác rỗng không numbers.push(item); } lấy giá trị trên đỉnh của stack ra, stack không đổi while (!numbers.empty( )) { 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 Khoa Công nghệ Thông tinĐH Bách Khoa Tp.HCM 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 Khoa Công nghệ Thông tinĐH Bách Khoa Tp.HCM Thiết kế stack enum Error_cod ...
Nội dung trích xuất từ tài liệu:
Cấu trúc dữ liệu và giải thuật - chương 2 A CCẤU TRÚC DỮ LIỆU VÀ B F GIẢI THUẬT (501040) D E G Chương 2: Stack K H 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 Khoa Công nghệ Thông tinĐH Bách Khoa Tp.HCM Ví dụ về stack Stack rỗng: Q Đẩy (push) Q vào: A Q Đẩy A vào: A Lấy (pop) ra một => được A: Q Lấy ra một => được Q và stack rỗng: Q 3 Chương 2: Stack Khoa Công nghệ Thông tinĐH Bách Khoa Tp.HCM Ứ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 Khoa Công nghệ Thông tinĐH Bách Khoa Tp.HCM Đả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 Khoa Công nghệ Thông tinĐH Bách Khoa Tp.HCM Đả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; đẩy một số vào trong stack for (int i = 0; i < n; i++) { cin >> item; kiểm tra xem stack có khác rỗng không numbers.push(item); } lấy giá trị trên đỉnh của stack ra, stack không đổi while (!numbers.empty( )) { 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 Khoa Công nghệ Thông tinĐH Bách Khoa Tp.HCM 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 Khoa Công nghệ Thông tinĐH Bách Khoa Tp.HCM Thiết kế stack enum Error_cod ...
Tìm kiếm theo từ khóa liên quan:
lập trình căn bản thủ thuật lập trình cấu trúc dữ liệu giải thuật tài liệu lập trìnhGợ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 317 0 0 -
114 trang 241 2 0
-
80 trang 221 0 0
-
Thủ thuật giúp giải phóng dung lượng ổ cứng
4 trang 215 0 0 -
NGÂN HÀNG CÂU HỎI TRẮC NGHIỆM THIẾT KẾ WEB
8 trang 207 0 0 -
Giải thuật và cấu trúc dữ liệu
305 trang 161 0 0 -
Hướng dẫn lập trình với Android part 4
5 trang 156 0 0 -
Bài giảng Phân tích thiết kế phần mềm: Chương 1 - Trường ĐH Ngoại ngữ - Tin học TP.HCM
64 trang 150 0 0 -
Tập bài giảng Thực hành kỹ thuật lập trình
303 trang 143 0 0 -
Giáo trình Cấu trúc dữ liệu và thuật toán (Tái bản): Phần 1
152 trang 139 0 0