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 - Nguyễn Tri Tuấn
lượt xem 2
download
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" trình bày các nội dung: Kiểu dữ liệu (Data type), kiểu dữ liệu cơ bản, kiểu dữ liệu có cấu trúc, kiểu dữ liệu trừu tượng, cấu trúc dữ liệu, đánh giá Cấu trúc dữ liệu. Mời các bạn cùng tham khảo.
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: Các khái niệm cơ bản - Nguyễn Tri Tuấn
- Cấu trúc dữ liệu & Giải thuật (Data Structures and Algorithms) Các khái niệm cơ bản Nguyễn Tri Tuấn Khoa CNTT – ĐH.KHTN.Tp.HCM Email: nttuan@fit.hcmus.edu.vn LOGO CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Nội dung 1 Kiểu dữ liệu (Data Type) 2 Kiểu dữ liệu cơ bản (Basic Data Type) 3 Kiểu dữ liệu có cấu trúc (Structured Data Type) 4 Kiểu dữ liệu trừu tượng (ADT – Abstract Data Type) 5 Cấu trúc dữ liệu (Data structure) 6 Đánh giá Cấu trúc dữ liệu www.themegallery.com 2 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Kiểu dữ liệu (1) Hãy viết ra ít nhất 5 kiểu dữ liệu mà bạn biết. Mô tả ngắn gọn các đặc điểm của mỗi kiểu dữ liệu 3 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Kiểu dữ liệu (2) Ví dụ: Kiểu số nguyên (int) Kiểu ký tự (char) Kiểu chuỗi (string) Kiểu mảng (array) … Định nghĩa tổng quát “Kiểu dữ liệu” T = V (Values - miền giá trị): tập hợp các giá trị mà kiểu T có thể nhận O (Operators – các thao tác): tập hợp các thao tác cơ bản được định nghĩa trên V 4 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Kiểu dữ liệu (3) Ví dụ T = short int (2 bytes) • V = {-32,768 .. +32,767} • O = {+, -, *, div, mod, >, >=, =, =,
- Kiểu dữ liệu cơ bản (1) Các ngôn ngữ lập trình (C/C++/Java,…) đều cung cấp sẵn các kiểu dữ liệu cơ bản để người lập trình sử dụng Các kiểu số nguyên: short int, int, long, char Kiểu logic: bool Các kiểu số thực: float, double 6 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Kiểu dữ liệu cơ bản (2) Kiểu dữ liệu Kích thước (size) Miền giá trị bool 1 byte ? char, unsigned char 1 byte ? short, unsigned short 2 bytes ? int, unsigned int 4 bytes ? long, unsigned long 4 bytes ? long long, unsigned long long 8 bytes ? float 4 bytes ? double 8 bytes ? 7 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Kiểu dữ liệu có cấu trúc (1) Người lập trình cũng có thể xây dựng các kiểu dữ liệu mới bằng cách kết hợp các kiểu cơ bản thành một kiểu cấu trúc: Kiểu mảng: array Kiểu chuỗi ký tự: string Kiểu struct Kiểu tập hợp: enum Kiểu union 8 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Kiểu dữ liệu có cấu trúc (2) Kiểu array: VD. int NumList[100]; // array gồm 100 int. Size = ? Kiểu string: VD. char Name[30]; // array gồm 30 char. Size = ? Kiểu struct: VD. struct DATE { unsigned short int Year, Month, Day; }; // Size = ? struct PERSON { char CardID[9]; // số CMND char Name[30]; struct DATE Birthday; float Weight; }; // Size = ? 9 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Kiểu dữ liệu có cấu trúc (3) Kiểu enum: enum BOOLEAN { false, // false = 0, true = 1 true }; enum BOOLEAN isCorrect = true; // giá trị của biến = 1 enum WEEKDAYS // tập hợp các ngày trong tuần { sunday, // sunday=0, monday=1, tuesday=2, … monday, tuesday, wednesday, thursday, friday, saturday }; enum WEEKDAYS today = thursday; 10 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Kiểu dữ liệu có cấu trúc (4) Kiểu union: // using_a_union.cpp #include union NumericType { char cValue; int iValue; double dValue; }; // Size = 8 bytes int main() { union NumericType Values; Values.iValue = 1000; printf("%d\n", Values.iValue); Values.dValue = 3.1416; printf("%f\n", Values.dValue); } 11 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Nội dung 1 Kiểu dữ liệu (Data Type) 2 Kiểu dữ liệu cơ bản (Basic Data Type) 3 Kiểu dữ liệu có cấu trúc (Structured Data Type) 4 Kiểu dữ liệu trừu tượng (ADT – Abstract Data Type) 5 Cấu trúc dữ liệu (Data structure) 6 Đánh giá Cấu trúc dữ liệu 12 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Kiểu dữ liệu trừu tượng (1) Định nghĩa ADT Là một tập các giá trị, cùng với các thao tác liên quan Không chỉ rõ cách thức cài đặt cụ thể (độc lập với cách thức cài đặt) Ví dụ: Stack ADT • Tập các phần tử • Các thao tác: push, pop, peak Có nhiều cách cài đặt Stack ADT: • Cài đặt dùng mảng 1 chiều • Cài đặt dùng danh sách liên kết 13 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Kiểu dữ liệu trừu tượng (2) Hãy cho 3 ví dụ về ADT mà bạn biết Mô tả các thao tác cơ bản Nêu ít nhất 2 cách cài đặt cho mỗi ADT 14 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Cấu trúc dữ liệu (1) Là cách thức tổ chức (organizing) và lưu trữ (storing) dữ liệu trong bộ nhớ (memory) để mang lại hiệu quả khi thi hành thuật toán Cấu trúc dữ liệu là cách thức cài đặt của ADT Danh sách liên kết (Linked list), hàng đợi (Queue), ngăn xếp (Stack), cây (Tree), từ điển (Dictionary), Heap,… External memory data structure 15 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Cấu trúc dữ liệu (2) Mỗi cấu trúc dữ liệu sẽ thích hợp cho một ứng dụng cụ thể B-cây thích hợp để dùng cho database Trình biên dịch thường dùng bảng băm (Hash table) để tìm kiếm Bảng băm cũng thường dùng cho ứng dụng Từ điển (dictionary) Hàng đợi (Queue) dùng cho ứng dụng phân phối hàng hoá … 16 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Nội dung 1 Kiểu dữ liệu (Data Type) 2 Kiểu dữ liệu cơ bản (Basic Data Type) 3 Kiểu dữ liệu có cấu trúc (Structured Data Type) 4 Kiểu dữ liệu trừu tượng (ADT – Abstract Data Type) 5 Cấu trúc dữ liệu (Data structure) 6 Đánh giá Cấu trúc dữ liệu 17 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Đánh giá Cấu trúc dữ liệu (1) Một cấu trúc dữ liệu được gọi là thích hợp cho một ứng dụng (A) nếu thoả được các điều kiện sau: Lưu trữ đầy đủ và đúng đắn dữ liệu của A Dễ dàng truy xuất và xử lý Tiết kiệm bộ nhớ 18 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Đánh giá Cấu trúc dữ liệu (2) Tính đầy đủ và đúng đắn: VD1. dữ liệu cần lưu là “điểm trung bình” int DiemTB; char DiemTB; float DiemTB; VD2. dữ liệu cần lưu là “ngày” [1-31] int Ngay; short int Ngay; unsigned short int Ngay; float Ngay; VD3. dữ liệu cần lưu là “năm” unsigned char Nam; unsigned int Nam; unsigned short int Nam; 19 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Đánh giá Cấu trúc dữ liệu (3) Tính đầy đủ và đúng đắn: VD4. dữ liệu cần lưu là “đơn giá mặt hàng (VND)” unsigned short int Dongia; unsigned int Dongia; float Dongia; unsigned long long Dongia; VD5. dữ liệu cần lưu là “đơn giá mặt hàng (USD)” unsigned short int Dongia; unsigned int Dongia; float Dongia; 20 CuuDuongThanCong.com https://fb.com/tailieudientucntt
CÓ THỂ BẠN MUỐN DOWNLOAD
-
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 | 174 | 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 và giải thuật trong C++ - Bài 8: Cấu trúc dữ liệu ngăn xếp
28 p | 77 | 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 | 116 | 9
-
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 | 57 | 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 (Trường Đại học Hồng Bàng )
62 p | 157 | 6
-
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 AA - Bùi Tiến Lên
30 p | 35 | 6
-
Bài giảng Cấu trúc dữ liệu - Chương 3: Cấu trúc cây
65 p | 58 | 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: Cấu trúc dữ liệu mảng với danh sách liên kết - Bùi Tiến Lên
36 p | 41 | 5
-
Bài giảng Cấu trúc dữ liệu: Chương 1 - ThS. Thiều Quang Trung (2018)
44 p | 43 | 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 | 105 | 4
-
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 | 113 | 4
-
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 AVL - Bùi Tiến Lên
38 p | 46 | 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: Chương 2 - Th.S Thiều Quang Trung
41 p | 68 | 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 | 50 | 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