Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 1 - ĐH Công nghệ Đồng Nai
lượt xem 23
download
Bài giảng Cấu trúc dữ liệu và giải thuật chương 1 : Tổng quan về cấu trúc dữ liệu và thuật toán trình bày về các tiêu chuẩn của thuật toán, biểu diễn thuật toán, đánh giá thuật giải, đồ thị hàm số, thực hiện và hiệu chỉnh chương trình, quy trình làm phần mềm. Tham khảo bài giảng để nắm bắt chi tiết môn học.
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 1 - ĐH Công nghệ Đồng Nai
- CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT TRƯỜNG ĐH CÔNG NGHỆ ĐỒNG NAI CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT Số tiết lý thuyết: 45 Số tiết thực hành: 30 1
- Tài Liệu Tham Khảo Trần Hạnh Nhi, Dương Anh Đức. Giáo trình Cấu Trúc Dữ Liệu 1, ĐHQG Tp. HCM, 2000. CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT Robert Sedgewick. Cẩm nang thuật toán (bản dịch của nhóm tác giả ĐH KHTN), NXB Khoa học kỹ thuật, 1994. P. S. Deshpande, O. G. Kakde. C & Data Structures, 2004. Dr. Dobb's. Algorithms and Data Structures, 1999 A.V. Aho, J.E Hopcroft, J.D Ullman. Data structures and Algorithms, Addison Wesley, 1983. 2
- Nội Dung Chương Trình Buổi 1: Giới thiệu về CTDL & Giải Thuật. Các thuật toán tìm kiếm. CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT Buổi 2: Interchange Sort, Selection Sort, Bubble Sort, Insertion Sort. Buổi 3: Shaker Sort, Shell Sort, Heap Sort. Buổi 4: Quick Sort, MergeSort, Radix Sort. Buổi 5: Cấu trúc động, Danh sách liên kết đơn. 3
- Nội Dung Chương Trình Buổi 6: Đệ qui, Stack, Queue. Buổi 7: Danh sách liên kết kép. CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT Buổi 8: Cây, Cây nhị phân, cây nhị phân tìm kiếm. Buổi 9: Cây cân bằng (AVL). Buổi 10: Các CTDL mở rộng. Buổi 11: Ôn tập. 4
- Hình Thức Thi Giữa kỳ: Seminar theo nhóm CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT Kiểm tra lý thuyết trên giấy Bài thu hoạch. Điểm cộng thêm Cuối kỳ: Thi trắc nghiệm trên máy Tổng điểm: 10 điểm. 5
- CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT CHƯƠNG 1 TỔNG QUAN VỀ CTDL VÀ THUẬT TOÁN TỔNG QUAN VỀ CTDL VÀ THUẬT TOÁN 6
- Nội Dung Tổng quan về CTDL và thuật toán Các tiêu chuẩn của CTDL CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT Vai trò của CTDL Độ phức tạp của thuật toán Thực hiện và hiệu chỉnh chương trình Tiêu chuẩn của chương trình 7
- Khái Niệm Về CTDL Và Thuật Toán Niklaus Wirth: CTDL + Thuật toán = Chương trình CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT Cần nghiên cứu về thuật toán và CTDL! 8
- Sự Cần Thiết Của Thuật Toán Tại sao sử dụng máy tính để xử lý dữ liệu? Nhanh hơn. Nhiều hơn. CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT Giải quyết những bài toán mà con người không thể hoàn thành được. Làm sao đạt được những mục tiêu đó? Nhờ vào sự tiến bộ của kỹ thuật: tăng cấu hình máy chi phí cao Nhờ vào các thuật toán hiệu quả: thông minh và chi phí thấp “Một máy tính siêu hạng vẫn không thể cứu vãn một thuật toán tồi!” 9
- Thuật Toán Thuật toán: Một dãy hữu hạn các chỉ thị có thể thi hành để đạt mục tiêu đề ra nào đó. Ví dụ: Thuật toán tính tổng tất cả các số nguyên CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT dương nhỏ hơn n gồm các bước sau: Bước 1: S=0, i=1; Bước 2: nếu i
- Các Tiêu Chuẩn Của Thuật Toán Xác định Hữu hạn CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT Đúng Tính hiệu quả Tính tổng quát 11
- Biễu Diễn Thuật Toán Dạng ngôn ngữ tự nhiên Dạng lưu đồ (sơ đồ khối) CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT Dạng mã giả Ngôn ngữ lập trình 12
- Biểu Diễn Bằng Ngôn Ngữ Tự Nhiên NN tự nhiên thông qua các bước được tuần tự liệt kê để biễu diễn thuật toán. CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT Ưu điểm: Đơn giản, không cần kiến thức về về cách biểu diễn (mã giả, lưu đồ,...) Nhược điểm: Dài dòng, không cấu trúc. Đôi lúc khó hiểu, không diễn đạt được thuật toán. 13
- Lưu Đồ Là hệ thống các nút, cung hình dạng khác nhau thể hiện các chức năng khác nhau. CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT A A Thực hiện A Gọi hàm A Vào / Ra dữ liệu Đúng B Begin End Sai Nút giới hạn bắt đầu / Điều kiện rẻ nhánh B kết thúc chương trình 14
- Biểu Diễn Bằng Lưu Đồ Bắt đầu amax = a0 Tìm phần tử mang giá trị lớn nhất CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT i= 1 trong mảng S amax là lớn nhất Kết thúc i
- Biểu Diễn Bằng Mã Giả Ngôn ngữ tựa ngôn ngữ lập trình: Dùng cấu trúc chuẩn hóa, chẳng hạn CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT tựa Pascal, C. Dùng các ký hiệu toán học, biến, hàm. Ưu điểm: Đỡ cồng kềnh hơn lưu đồ khối. Nhược điểm: Không trực quan bằng lưu đồ khối. 16
- Biểu Diễn Bằng Mã Giả Một số quy ước 1. Các biểu thức toán học 2. Lệnh gán: “=” (AB) CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT 3. So sánh: “==”, “!=” 4. Khai báo hàm (thuật toán) Thuật toán () Input: Output: End 17
- Biểu Diễn Bằng Mã Giả 5. Các cấu trúc: Cấu trúc chọn: if … then … [else …] fi CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT Vòng lặp: while … do do … while (…) for … do … od 6. Một số câu lệnh khác: Trả giá trị về: return [giá trị] Lời gọi hàm: (tham số) 18
- Biểu Diễn Bằng Mã Giả Ví dụ: Tìm phần tử lớn nhất trong mảng một chiều. CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT amax=a0; i=1; while (i
- Biểu Diễn Bằng Ngôn Ngữ Lập Trình Dùng ngôn ngữ máy tính (C, Pascal,...) để diễn tả thuật toán, CTDL thành câu lệnh. CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT Kỹ năng lập trình đòi hỏi cần học tập và thực hành (nhiều). Dùng phương pháp tinh chế từng bước để chuyển hoá bài toán sang mã chương trình cụ thể. 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 - 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 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 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: 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: 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 3: Cấu trúc cây
65 p | 59 | 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 (2016)
62 p | 94 | 6
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 7 - Châu Thị Bảo Hà
133 p | 115 | 4
-
Bài giảng Cấu trúc dữ liệu: Chương 5 - Cấu trúc dữ liệu cây
32 p | 86 | 4
-
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 6 - Ngô Quang Thạch
41 p | 106 | 4
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 5 - Ngô Quang Thạch
24 p | 58 | 3
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Bài 1b - Hoàng Thị Điệp (2014)
29 p | 30 | 3
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 2 - Th.S Thiều Quang Trung
41 p | 70 | 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
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Bài 1a - Hoàng Thị Điệp (2014)
12 p | 59 | 1
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