Bài giảng Kỹ Thuật lập trình - Chương 2: Giải thuật và cấu trúc dữ liệu - Vũ Thị Hương Giang

Mỗi nút trên cây liên kết đến nút gốc của cây con bên trái và bên phải • Cây nhị phân tìm kiếm (BST) - Khóa của nút gốc lớn (hay nhỏ) hơn khóa của tất cả các nút của cây con bên trái (hay bên phải) - Các cây con (bên trái, phải) là BST • Cây cân bằng (AVL) - BST - Tại nút bất kỳ, chiều cao nhánh trái và nhánh phải chênh nhau không quá 1.• Bảng băm - Bảng - Vị trí của 1 phần tử được tính bằng hàm băm • Hàm băm: - Đầu vào: giá trị cần băm (giá trị phần tử đầu vào) - Đầu ra: giá trị băm (khóa, giúp xác định vị trí của giá trị cần băm) - Có khả năng trùng khóa (đụng độ), ví dụ f(x) = X % m; - Cần tìm hàm băm sao cho khả năng đụng độ là nhỏ nhất (luôn luôn tìm ra đúng giá trị phần tử đầu vấo khi sử dụng khóa) - Đảm bảo 0(1) - Ví dụ: • f(x) = X % m; • f('abc') = (char_index('a')*base_number2 + char_index('b')*base_numberl + char_index('c')*base_numberO) % hash_size

docx40 trang | Chia sẻ: hachi492 | Ngày: 07/01/2022 | Lượt xem: 335 | Lượt tải: 0download
Bạn đang xem trước 20 trang tài liệu Bài giảng Kỹ Thuật lập trình - Chương 2: Giải thuật và cấu trúc dữ liệu - Vũ Thị Hương Giang, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
CHƯƠNG II. GIẢI THUẬT yÀ CÂU TRÚC DỮ LIỆU • với mỗi bài toán, làm thế nào để: Thiết kê' giải thuật nhằm giải quyết bài toán đó Cài đặt giải thuật bằng một chương trình máy tính 1. Analyze Requirements 6. Doi Hãy thiết kế giải thuật hay Lnhat có thể: đơn giản hóa bài toán đặt ra Sau đó hãy nghĩ tới việc viết mã nguồn 4. Implementation 3. Design Mở đầu Các bài toán thực tế thường phức tạp Hiểu bài toán đặt ra == để giải quyết bài toán, cần làm gì, không cần làm gì. Do đó, phải xác định được: Các dữ liệu liên quan đến bài toán Các thao tác cần thiết để giải quyết bài toán Làm chủ ngôn ngữ lập trình để cài đặt giải pháp thành chương trình máy tính - Tìm kiếm thông tin về 1 nhân viên ví dụ: Bài toán quản một cơ quan • Cần quản lỵ những thông tin nào ? - Thông tin về nhân viên: tên^ngàỵ sinh, số bảo hiemTxa hôi, phòng ban làm việc, ... -ì nhân viên ảo'  lý nhân viên của Cần thực hiện những thao tá'c quán lý nàố ? Tạo ra hồ sơ cho nhân viên mới vào làm Cập nhật một sô\ thong tín trông hồ sơ • Ai được phép thực hiện thao tác nào? ví dụ: tính tổng của n số tự nhiên kể từ m void main() { long n,m,i, sum ; cout << ' vào n ' ; cin << n; cout << ' vào m ' ; cin << m; sum =0; for(i = m ; i < m + n; i++) sum += i; cout << ' Tống = ' <<sum; void main() long n,m , sum ; cout << ' vào n ' ; cin << n; cout << ' vào m ' ; cin << m; sum =(m + m + n) * n / 2; cout << ' Tông = ' <<sum; GIẢI THUẬT Đặc trưng của giải thuật Đầu vào (Input): dữ liệu nào, lấy từ đâu Đầu ra (Output): dữ liệu đầu ra tương ứng với dữ liệu đầu vào và các bước xử lý Độ chính xác (Precision): các bước xử lý được mô tả chính xác Hữu hạn (Finiteness): tạo ra đầu ra sau một số hữu hạn các bước xử lý Đơn trị (Uniqueness): Các kết quả trung gian của từng bước xử lý là duy nhất, không thể thay đổi Tổng quát (Generality): có thể áp dụng cho các bài toán đồng dạng I, Giải thuật Tìm kiếm • Input: Một tập các phần tử dữ liệu có cấu trúc Một khóa cần tìm • Process: - Tìm phần tử có chứa khóa trùng với khóa cần tìm • Output: - Vị trí của phần tử có chứa khóa (nếu có) Phần tử dữ liệu có cấu trúc và khóa • Phần tử dữ liệu có cấu trúc: Dữ liệu khóa Các dữ liệu thành phần khác / Leblanc \ 7 Johnson - So sánh được • Có thể là giá trị của phần tử Khóa: • Có thể là dữ liệu thành phần của phần tử Thường là số • Trích khóa từ các phần tử dữ liệu có cấu trúc: So sánh các dữ liệu thành phần Các giải thuật tìm kiếm phô biến Tìm kiêm tuân tự Các phần tử trong tập đầu vào không được sắp xếp theo khóa tìm kiếm Quá trình xử lý Duyệt tập đầu vào So sánh với khóa cần tìm tới khi tìm thấy khóa hoặc duyệt qua hết tập đầu vào mà chưa tìm thấy  Tìm kiêm nhị phân Các phần tử trong tập đầu vào được sắp xềp theo khóa tìm kiếm Quá trình xử lý So sánh khóa cần tìm với phần tử giữa. Nếu nó nhỏ hơn thì tìm bên trái tập đầu vào. Ngược lại tìm bên phải tập đầu vào. Lặp lại động tác này. 2. Sắp xếp Chương n. Nâng cao vẽ„ giải thuật, câu trúc dữ liệu va ngôn ngữ lập trình I. Giải thuật sắp thứ tự: Đầu vào: tập các phần tử dữ liệu Đầu ra: danh sách có thứ tự tăng (hoặc giảm) theo khóa Phân loại: sắp thứ tự theo khóa ngoài (external sort): tập tin Sắp thứ tự theo khóa chính (internal sort): bộ nhớ Giả thiết: sắp thứ tự theo khóa chính Sắp tăng dần Các giải thuật sắp xếp phổ biến Insertion sort Selection sort Bubble sort Merge sort Quick sort Heap sort 3. Độ phức tạp tính toán I, Giải thuật g(n) = 1 g(n) = log n g(n) = n g(n) = n2 g(n) = n3 g(n) = 2n So sánh với các hàm cơ bản: Constant function Logarithmic function Linear function Quadratic function Cubic function Exponential function Độ tăng của các hàm chung n 1 IgH lì M Ig n n2 n3 2" 1 1 0.00 1 0 1 1 2 10 1 3.32 10 33 100 1000 1024 100 1 6.64 100 664 10,000 1,000,000 1.27 X 1O30 1000 1 9.97 1000 9970 1,000,000 109 1.07 X 1O301 Độ phức tạp tính bằng tiệm cận Tn /(//) f(n) has strictly smaller order of magnitude than g(/ỉ). Definition If lim — - = 0 then: M-*oo g(n) If lim ■ is finite and nonzero then: n->oo £(n) /(/?) has the same order of magnitude as g(n). If lim ' = 00 then: n^oo g(n) f(n) has strictly greater order of magnitude than g(n). Ký pháp f(n)e Bậc của f so với g limn.>00 (f(n)/g(n) o(g(n)) < : nhỏ hơn hẳn 0 0(g(n)) < : nhỏ hơn hoặc bằng a 0(g(n)) = : bằng a 5*0 Đ(g(n)) > : lớn hơn hoặc bằng a # 0 hoặc là 00 Thứ tư tăng dần về đô lởn: 0(1) 0(lg n) O(n) 0(n Ig n) O(n2) 0(n3) O(2n) II. CÂU TRÚC DỮ LIỆU a. Cấu trúc dữ liệu Chương n. Nâng cao ve^ giải thuật, câu trúc dữ liệu và ngôn ngữ lập trình Giải thuật Cấu trúc dữ liệu 1. Các khái niệm cơ bàn Cấu trúc dữ liệu là cách tổ chức và thao tác có hệ thống trên dữ liệu 1 cấu trúc dữ liệu : Mô tả Các dữ liệu cấu thành Mối liên kết về mặt cấu trúc giữa các dữ liệu đó Cung cấp các thao tác trên dữ liệu đó Đặc trưng cho 1 kiểu dữ liệu b. Kiểu dữ liệu Kiểu dữ liệu cơ bản (primitive'data type) Đại diện cho các dữ liêu giồng nhau, không thể phân chia nhỏ hơn được nữa Thường được các ngôn ngữ lập trình định nghĩa san Ví dụ: C/C+ + : int, long, char, boolean, v.v. Thao tác trên các số nguyên: +-*/... Kiểu dữ liệu có câu trúc (structured data type) Được xây dựng từ các kiểu dữ liệu (cơ bản, có cấu trúc) khác Có thể được các ngôn ngữ lập trình định nghĩa sẵn hoặc do lập trình viên tự định nghĩa ADT Operations Interface c. Kiểu dữ liệu trừu tượng (Abstract data type) 1 ADT là' một kiếu dữ liệu đi' kèm ’vớị các thạp tác trên các dữ liệu kiểu đó 1JXDT mô hinhj'ioa các dữ liệu cùng kiểu thẹo cặclíkhông phu thuộc vào ngôn ngữ lập trình hay môi trương’cài đặt Các ngôn ngữ lập trình hướng 'đối tượng cho phép cài đặt ì ADT dưới dạng 1 lớp(class) Mảng (Array) Tập các cặp (index, element) Với mỗi giá trị của index sẽ có một giá trị tương ứng của element • Cài đặt: Sử dụng một không gian nhớ liên tiếp Index: kiểu giá trị phụ thuộc vào ngôn ngữ lập trình c, Java : kiểu sổ nguyên, tăng liên tục, bẳt đầu từ 0 Pascal : kiểu số nguyên Perl: chì số không nhất thiết phải là kiểu số element: kiểu giá trị bất kỳ (kiểu dựng sẵn hoặc kiểu có cấu trúc) Tất cà các phần tử cùng kiểu: màng thuần nhất. NgƯỢc lại: màng không thuần nhất SizeOf(element) . 1 Index: chỉ số chỉ thứ tự Element: phần tử Mảng (Array) Các kiểu mảng Mảng 1 chiều Mảng 2 chiều Thao tác trên mảng: Khởi tạo mảng (create) Tính kích thước (sizeOf) Lấy một phần tử tại một vị trí cụ thế (retrieve) Thay thế giá trị của một phần tử tại một vị trí cụ thể (replace) Bài tập: Khởi tạo giá trị cho mảng y[5] = {3.2,1.2,4.5,6.0,3.6}; m[6][2] = {{1,1},{1,2},{2,1},{2,2},{3,1},{3,2}}; char sl[6] ={ , JaJ, JnJ, *OJ,'i?, J\0J}; //Hoac char sl[] = "DH Bach Khoa Hanoi”; //length = int m[][] = {{1,2,3},{4,5,6}}; int m[4]; m[0] = 1, m[l] = 2; m[2] = 3; m[3] = 4; Danh sách (List) Danh sách : Tập hợp các phần tử cùng kiểu Số lượng các phần tử của danh sách không cố định Phân loại: Danh sách tuyến tính: Có phần tử đầu tiên, phần tử cuổi cùng Thứ tự trước / sau cùa các phần tư được xác định rõ ràng, ví dụ sắp theo thứ tự tăng dần, giảm dần hay thứ tự trong bàng chữ cái Các thao tác trên danh sách phải không làm ảnh hưởng đến trật tự này Danh sách không tuyến tính: các phần tử trong danh sách không được sắp thứ tự CÓ nhiều hình thức lưu trữ danh sách Danh sách kế tiếp: sử dụng vùng các ô nhớ liên tiếp trong bộ nhớ Danh sách liên kết: sử dụng vùng các ô nhớ không liên tiếp trong bộ nhớ Danh sách nối đơn Danh sách nối kép Danh sách nối vòng Danh sách (List) • Thao tác trên danh sách tuyến tính Khởi tạo danh sách (create) Kiếm tra danh sách rỗng (isEmpty) Kiểm tra danh sách đầy (isFull) Tính kích thước (sizeOf) Xóa rỗng danh sách (clear) Thêm một phần tử vào danh sách tại một ví trí cụ thể (insert) Loại bỏ một phần tử tại một vị trí cụ thể khỏi danh sách (remove) Lấy một phần tử tại một vị trí cụ thể (retrieve) Thay thế giá trị của một phần tử tại một vị trí cụ thể (replace) Duyệt danh sách và thực hiện một thao tác tại các vị trí trong danh sách (traverse) So sánh các hình thức lưu trữ danh sách Sử dụng vùng các ô nhớ liên tiếp: thích hỢp khi Sử dụng vùng các ô nhớ khống liến tiếp: thích hỢp khi - Kích thước từng phần tử là rất nhỏ Kích thước của cả danh sách (số phần tử) đã biết khi lập trình Có ít sự thêm vào hay loại bỏ ở giữa danh sách Hình thức truy cập trực tiếp là quan trọng - Kích thước từng phần tử là lớn Kích thước của danh sách không biết trước Có nhiều sự thêm vào, loại bỏ, hay sắp xếp cac phần tứ trong danh sách Cấu trúc dữ liệu đệ quy • Đôi khi LTV cần đến các cấu trúc dữ liệu đệ quy (cấu trúc chứa chính nó) • Ví dụ: từ điển điện tử, mỗi từ trong từ điển được biểu diên bằng một cấu trúc dữ liệu, trong đó, mục từ đồng nghĩa cũng là từ có cùng cấu trúc C: làm thê' nào để một cấu trúc có thể chứa chính nó Trong ngôn ngữ lập trình c, một cấu trúc (struct) không thể chứa chính nó Nhưng một cấu trúc có thể chứa con trỏ trỏ đến cấu trúc cùng kiểu struct silly_struct { /* This doesn't work */ struct silly_struct si; in struct good_struct { /* This does work */ struct *good_struct s2; }; Danh sách liên kết: cách biểu diễn đơn giản cấu trúc dữ liệu đệ quy • ví dụ: cần đọc các dòng trong một tệp tin, nhưng không biết cần đọc bao nhiêu dòng -> cần một cấu trúc có thê’ tự mở rộng head of list information information information nextptr. nextptr nextptr= NULL 30 sổ địa chỉ cài đặt bằng danh sách nối đơn typedef struct list { char name[MAXLEN]; char address[MAXLEN]; char phone[MAXLEN]; struct list *next; } ADDRESS; ADDRESS *hol= NULL; /* Set the head of the list */ Cây nhị phân (binary tree) Định nghĩa cây rỗng Hoặc có một nút gọi là gốc (root) và 2 cây con gọi là cây con trái và cây con phải Ví dụ: Cây rỗng: Cây có 1 nút: là nút gốc Cây có 2 nút: Phép duyệt cây Duyệt qua từng nút của cây (mỗi nút 1 lần) Cách duyệt: Thứ tự trước (preorder hay NLR) Thứ tự giữa (inorder hay LNR) Thứ tự sau (postorder hay LRN) Kết quả: Kết quả: Kết quả: Các loại cây nhị phân • cây nhị phân liên kết - Mỗi nút trên cây liên kết đến nút gốc của cây con bên trái và bên phải Cây nhị phân tìm kiếm (BST) Khóa của nút gốc lớn (hay nhỏ) hơn khóa của tất cả các nút của cây con bên trái (hay bên phải) Các cây con (bên trái, phải) là BST Cây cân bằng (AVL) - BST - Tại nút bất kỳ, chiều cao nhánh trái và nhánh phải chênh nhau không quá 1. Bảng băm (hash table) Bảng băm Bảng Vị trí của 1 phần tử được tính bằng hàm băm Hàm băm: Đầu vào: giá trị cần băm (giá trị phần tử đầu vào) Đầu ra: giá trị băm (khóa, giúp xác định vị trí của giá trị cần băm) Có khả năng trùng khóa (đụng độ), ví dụ f(x) = X % m; Cần tìm hàm băm sao cho khả năng đụng độ là nhỏ nhất (luôn luôn tìm ra đúng giá trị phần tử đầu vấo khi sử dụng khóa) Đảm bảo 0(1) Ví dụ: f(x) = X % m; f('abc') = (char_index('a')*base_number2 + char_index('b')*base_numberl + char_index('c')*base_numberO) % hash_size ví dụ dùng bảng băm Không có

Các file đính kèm theo tài liệu này:

  • docxbai_giang_ky_thuat_lap_trinh_chuong_2_giai_thuat_va_cau_truc.docx
  • pdfKTLT02-sv.pdf
Tài liệu liên quan