Bài giảng Thuật toán ứng dụng: Đồ thị nâng cao
lượt xem 5
download
Bài giảng "Thuật toán ứng dụng: Đồ thị nâng cao" trình bày các nội dung chính sau đây: Đồ thị có trọng số; Cấu trúc dữ liệu các tập không giao nhau – UNION-FIND; Cây khung nhỏ nhất - MST; Đường đi ngắn nhất; Một số bài toán kinh điển trên đồ thị; Một số đồ thị đặc biệt. 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 Thuật toán ứng dụng: Đồ thị nâng cao
- Đồ Thị Nâng Cao THUẬT TOÁN ỨNG DỤNG
- 1 Đồ thị có trọng số 2 Cấu trúc dữ liệu các tập không giao nhau – UNION-FIND 3 Cây khung nhỏ nhất - MST 4 Đường đi ngắn nhất 5 Một số bài toán kinh điển trên đồ thị 6 Một số đồ thị đặc biệt 3 / 59
- 1 Đồ thị có trọng số 2 Cấu trúc dữ liệu các tập không giao nhau – UNION-FIND 3 Cây khung nhỏ nhất - MST 4 Đường đi ngắn nhất 5 Một số bài toán kinh điển trên đồ thị 6 Một số đồ thị đặc biệt 4 / 59
- Đồ thị có trọng số Trong phần này ta xét đồ thị mà mỗi cạnh của nó có trọng số đi kèm giá trị trên cạnh trọng số trên cạnh ví dụ: khoảng cách của con đường, chi phí truyền thông giữa hai nút mạng, . . . Biểu diễn đồ thị có trọng số bởi danh sách kề mở rộng 5 / 59
- Đồ thị có trọng số struct edge { int u , v ; 1 int weight ; 9 -7 edge ( int _u , int _v , int _w ) { 0 u = _u ; 2 3 v = _v ; weight = _w ; 5.1 } }; 4 6 / 59
- Đồ thị có trọng số vector < edge > Adj [5]; 1 Adj [1]. push_back ( edge (1 , 2 , 9)); Adj [1]. push_back ( edge (1 , 3 , -7)); 9 -7 0 Adj [2]. push_back ( edge (2 , 1 , 9)); 2 3 Adj [2]. push_back ( edge (2 , 3 , 0)); 5.1 Adj [3]. push_back ( edge (3 , 1 , -7)); Adj [3]. push_back ( edge (3 , 2 , 0)); 4 Adj [3]. push_back ( edge (3 , 4 , 5.1)); Adj [4]. push_back ( edge (4 , 3 , 5.1)); 7 / 59
- 1 Đồ thị có trọng số 2 Cấu trúc dữ liệu các tập không giao nhau – UNION-FIND 3 Cây khung nhỏ nhất - MST 4 Đường đi ngắn nhất 5 Một số bài toán kinh điển trên đồ thị 6 Một số đồ thị đặc biệt 8 / 59
- Union-Find Cho n phần tử Cần quản lý vào các tập không giao nhau Mỗi phần tử ở trong đúng 1 tập Items = {1, 2, 3, 4, 5, 6} Collections = {1, 4}, {3, 5, 6}, {2} Collections = {1}, {2}, {3}, {4}, {5}, {6} Hai toán tử hiệu quả: Find(x) và Union(x,y). 9 / 59
- Union-Find Items = {1, 2, 3, 4, 5, 6} Collections = {1, 4}, {3, 5, 6}, {2} Find(x) trả về phần tử đại diện của tập chứa x Find(1) = 1 Find(4) = 1 Find(3) = 5 Find(5) = 5 Find(6) = 5 Find(2) = 2 a và b thuộc cùng một tập khi và chỉ khi Find(a) == Find(b) 10 / 59
- Union-Find Items = {1, 2, 3, 4, 5, 6} Collections = {1, 4}, {3, 5, 6}, {2} Union(x, y) trộn tập chứa x và tập chứa y vào nhau union(4, 2) Collections = {1, 2, 4}, {3, 5, 6} union(3, 6) Collections = {1, 2, 4}, {3, 5, 6} union(2, 6) Collections = {1, 2, 3, 4, 5, 6} 11 / 59
- Cài đặt Union-Find Hợp nhất nhanh với kỹ thuật nén đường (Quick Union with path compression) Cực kỳ dễ cài đặt Cực kỳ hiệu quả 1 struct Union_Find { 2 vector < int > iParent ; 3 Union_Find ( int n ) { 4 iParent = vector < int >( n ); 5 for ( int i = 0; i < n ; ++ i ) { 6 iParent [ i ] = i ; 7 } 8 } 9 // toan tu Find va Union 10 }; 12 / 59
- Cài đặt Union-Find 1 // toan tu Find va Union 2 3 int Find ( int x ) { 4 if ( iParent [ x ] == x ) { 5 return x ; 6 } else { 7 iParent [ x ] = Find ( iParent [ x ]); // Nen parent 8 return iParent [ x ]; 9 } 10 } 11 12 void Unite ( int x , int y ) { 13 iParent [ Find ( x )] = Find ( y ); 14 } 13 / 59
- Ứng dụng của Union-Find Union-Find quản lý các tập không giao nhau Xử lý từng loại các tập không giao nhau tùy thời điểm Các bài toán ứng dụng quen thuộc thường trên đồ thị 14 / 59
- Union-Find trên đồ thị 1 7 2 4 5 3 6 15 / 59
- Union-Find trên đồ thị 1 7 2 4 5 3 6 items = {1, 2, 3, 4, 5, 6, 7} 15 / 59
- Union-Find trên đồ thị 1 7 2 4 5 3 6 items = {1, 2, 3, 4, 5, 6, 7} collections = {1, 4, 7}, {2}, {3, 5, 6} 15 / 59
- Union-Find trên đồ thị 1 7 2 4 5 3 6 items = {1, 2, 3, 4, 5, 6, 7} collections = {1, 4, 7}, {2}, {3, 5, 6} union(2, 5) 15 / 59
- Union-find trên đồ thị 1 7 2 4 5 3 6 Items = {1, 2, 3, 4, 5, 6, 7} Collections = {1, 4, 7}, {2, 3, 5, 6} 16 / 59
- Union-find trên đồ thị 1 7 2 4 5 3 6 Items = {1, 2, 3, 4, 5, 6, 7} Collections = {1, 4, 7}, {2, 3, 5, 6} Union(6, 2) 16 / 59
CÓ THỂ BẠN MUỐN DOWNLOAD
-
Bài giảng Thuật toán ứng dụng: Quy hoạch động - Trương Xuân Nam
25 p | 50 | 8
-
Bài giảng Thuật toán ứng dụng: Quy hoạch động
32 p | 39 | 7
-
Bài giảng Thuật toán ứng dụng: Thuật toán Tham lam - Trương Xuân Nam
23 p | 77 | 7
-
Bài giảng Thuật toán ứng dụng: Đệ quy quay lui
66 p | 51 | 7
-
Bài giảng Thuật toán ứng dụng: Thuật toán tham lam
42 p | 14 | 7
-
Bài giảng Thuật toán ứng dụng: Thuật toán cơ bản trên đồ thị không trọng số
182 p | 9 | 5
-
Bài giảng Thuật toán ứng dụng: Thuật toán xử lý xâu
89 p | 12 | 5
-
Bài giảng Thuật toán ứng dụng: Tiếp cận chia để trị - Trương Xuân Nam
21 p | 45 | 5
-
Bài giảng Thuật toán ứng dụng: Đệ qui và nhánh cận
48 p | 17 | 4
-
Bài giảng Thuật toán ứng dụng: Tư duy thuật toán và cấu trúc dữ liệu, kỹ năng lập trình
55 p | 13 | 4
-
Bài giảng Thuật toán ứng dụng: Tarjan DFS algorithm for finding bridges and articulation points
21 p | 20 | 4
-
Bài giảng Thuật toán ứng dụng: Graphs
141 p | 27 | 4
-
Bài giảng Thuật toán ứng dụng: Lý thuyết NP-đầy-đủ
53 p | 15 | 4
-
Bài giảng Thuật toán ứng dụng: Chương 1 - Đỗ Phan Thuận
46 p | 35 | 4
-
Bài giảng Thuật toán ứng dụng: Chương 3 - Đỗ Phan Thuận
32 p | 31 | 3
-
Bài giảng Thuật toán ứng dụng: Chương 2 - Đỗ Phan Thuận
45 p | 23 | 3
-
Bài giảng Thuật toán ứng dụng: Đồ thị - Trương Xuân Nam
32 p | 39 | 3
-
Bài giảng Thuật toán ứng dụng: Thuật toán và Phân tích Thuật toán - Trương Xuân Nam
34 p | 61 | 3
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