Bài giảng Lý thuyết đồ thị: Chương 2 - Tôn Quang Toại
lượt xem 3
download
Bài giảng Lý thuyết đồ thị: Chương 2 Biểu diễn đồ thị trên máy tính, cung cấp cho người đọc những kiến thức như: Biểu diễn đồ thị bằng ma trận kề, ma trận số; Biểu diễn đồ thị bằng Danh sách kề; Biểu diễn đồ thị bằng danh sách cạnh. 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 Lý thuyết đồ thị: Chương 2 - Tôn Quang Toại
- CHƯƠNG 2 BIỂU DIỄN ĐỒ THỊ TRÊN MÁY TÍNH Tôn Quang Toại Khoa CNTT, Đại học Ngoại ngữ ‐ Tin học TP.HCM
- Nội dung Biểu diễn đồ thị bằng Ma trận kề, ma trận số Biểu diễn đồ thị bằng Danh sách kề Biểu diễn đồ thị bằng Danh sách cạnh
- BIỂU DIỄN ĐỒ THỊ BẰNG MA TRẬN KỀ, MA TRẬN TRỌNG SỐ
- Ma trận kề Đồ thị G=(V, E) có n đỉnh ( ) và m cạnh. Ma trận kề (adjacency matrix) của G là một mảng 2 chiều , trong đó cho biết G chứa những cạnh (i,j) hay không 1 𝑛ế𝑢 𝑐ạ𝑛ℎ 𝑖, 𝑗 ∈ 𝐸 𝑣 𝑖, 𝑗 0 𝑛ế𝑢 𝑐ạ𝑛ℎ 𝑖, 𝑗 ∉ 𝐸
- Ma trận kề Ví dụ: Graph vô hướng 2 4 0 5 1 3 0 1 2 3 4 5 0 1 2 v = 3 4 5
- Ma trận kề Ví dụ: Graph có hướng 2 4 0 5 1 3 0 1 2 3 4 5 0 1 2 v = 3 4 5
- Ma trận kề Cấu trúc dữ liệu int[,] v; int n; Cấu trúc file dữ liệu của ma trận kề Graph.INP Số đỉnh 6 0 1 1 0 0 0 1 0 1 1 1 0 1 1 0 0 1 0 Ma trận kề 0 1 0 0 1 1 0 1 1 1 0 1 0 0 0 1 1 0
- Ma trận kề Một số tính chất của ma trận kề Ma trận kề của đồ thị vô hướng là ma trận đối xứng: Ngược lại, ma trận đối xứng (0,1) bậc n sẽ tương ứng với đồ thị vô hướng n đỉnh Nếu đồ thị vô hướng: Số lượng số 1 trên dòng thứ i = Số lượng số 1 trên cột thứ i = deg(i) Nếu đồ thị có hướng: • Số lượng số 1 trên dòng i = tổng bậc ra của đỉnh i = deg+(i) • Số lượng số 1 trên cột i = tổng bậc vào của đỉnh i = deg ‐(i)
- Ma trận kề Một số thao tác cơ bản trên cấu trúc Graph Kiểm tra có 1 cạnh nối đỉnh u đến đỉnh v không Xét các đỉnh kề với đỉnh u cho trước Thêm 1 cạnh nối đỉnh u đến đỉnh v nếu chưa có cạnh đó Xóa cạnh nối đỉnh u đến đỉnh v nếu có cạnh đó Xóa cạnh nối đỉnh u đến đỉnh v nếu có cạnh đó nhưng cho phép phục hồi lại sau này Xóa các cạnh kề với đỉnh u và xóa cả đỉnh u
- Ma trận trọng số Đồ thị có trọng số: Mỗi cạnh e=(u,v) của đồ thị được gán với một con số w(u, v) gọi là trọng số của cạnh e. Trong trường hợp đồ thị có trọng số, thay vì dùng ma trận kề, chúng ta biểu diễn đồ thị bằng ma trận trọng số như sau 𝑤 𝑖, 𝑗 𝑛ế𝑢 𝑐ạ𝑛ℎ 𝑖, 𝑗 ∈ 𝐸 𝑣 𝑖, 𝑗 0 𝑛ế𝑢 𝑐ạ𝑛ℎ 𝑖, 𝑗 ∉ 𝐸
- Ma trận trọng số 2 6 4 Ví dụ: 3 3 4 5 0 1 3 9 5 2 1 3 0 1 2 3 4 5 0 1 2 v = 3 4 5
- GIỚI THIỆU COLLECTION
- Một số loại collection cơ bản Collection tuyến tính LinkedList Tuple Stack Queue Collection không tuyến tính SortedSet SortedDictionary
- LinkedList LinkedList: LinkedList là một cấu trúc dữ liệu cho phép chúng ta thêm, xóa phần tử với thời gian O(1) Tạo LinkedList và thêm các phần tử vào list LinkedList list = new LinkedList(); list.AddLast(4); list.AddLast(7); list.AddLast(3);
- LinkedList Truy cập các phần tử trong LinkedList foreach (int x in list) Console.Write(x + " "); for (LinkedListNode node = list.First; node!=null; node=node.Next) Console.Write(node.Value + " ");
- LinkedList Properties First Last Count Methods AddLast() AddFirst() Find()
- Tuple Tuple: Tuple là một cấu trúc dữ liệu có một số phần tử tuần tự Tạo tuple chứa 2 số nguyên Tuple tuple; tuple= new Tuple(2,3); Console.Write(tuple.Item1 + " " + tuple.Item2);
- Stack Stack: Stack là cấu trúc dữ liệu cung cấp 2 phép toán có thời gian chạy O(1): Thêm phần tử vào đầu (top) stack Xóa phần tử ở đầu stack Stack s = new Stack(); s.Push(5); s.Push(7); Console.Write(s.Peek()); s.Pop(); Console.Write(s.Peek());
- Stack Property Count Methods Push() Pop() Peek()
- Queue Queue: Queue là cấu trúc dữ liệu cung cấp 2 phép toán có thời gian chạy O(1): Thêm phần tử vào cuối queue Xóa phần tử đầu tiên trong queue Queue q = new Queue(); q.Enqueue(5); q.Enqueue(7); Console.Write(q.Peek()); q.Dequeue(); Console.Write(q.Peek());
CÓ THỂ BẠN MUỐN DOWNLOAD
-
Bài giảng Lý thuyết đồ thị: Chương 7 - Bài toán luồng cực đại trong mạng
15 p | 171 | 22
-
Bài giảng Lý thuyết đồ thị: Chương 5 - Nguyễn Trần Phi Phượng
20 p | 137 | 20
-
Bài giảng Lý thuyết đồ thị: Chương 3 - Đồ thị Euler và đồ thị Hamilton
19 p | 149 | 16
-
Bài giảng Lý thuyết đồ thị - Bài 2: Đường đi, chu trình Euler
26 p | 81 | 8
-
Bài giảng Lý thuyết đồ thị - Học viện Kỹ thuật Quân sự
107 p | 92 | 7
-
Bài giảng Lý thuyết đồ thị: Chương 0 - Giới thiệu môn học
12 p | 105 | 7
-
Bài giảng Lý thuyết đồ thị - Bài 9: Bài toán ghép cặp
26 p | 78 | 6
-
Bài giảng Lý thuyết đồ thị: Chương 3 - Nguyễn Trần Phi Phượng
14 p | 100 | 5
-
Bài giảng Lý thuyết đồ thị - Bài 1: Đại cương về đồ thị
39 p | 39 | 5
-
Bài giảng Lý thuyết đồ thị - Bài 3: Đường đi, chu trình Hamilton
34 p | 76 | 5
-
Bài giảng Lý thuyết đồ thị - Bài 5: Cây khung của đồ thị
17 p | 61 | 5
-
Bài giảng Lý thuyết đồ thị: Chương 0 - Tôn Quang Toại
6 p | 11 | 4
-
Bài giảng Lý thuyết đồ thị: Chương 4 - Nguyễn Trần Phi Phượng
13 p | 122 | 4
-
Bài giảng Lý thuyết đồ thị: Chương 0 - Nguyễn Trần Phi Phượng
6 p | 94 | 4
-
Bài giảng Lý thuyết đồ thị - Bài 6: Biểu diễn đồ thị trên máy tính
31 p | 69 | 3
-
Bài giảng Lý thuyết đồ thị: Chương 1 - Ngô Hữu Phúc
38 p | 38 | 3
-
Bài giảng Lý thuyết đồ thị: Chương 3 - Ngô Hữu Phúc
18 p | 47 | 3
-
Bài giảng Lý thuyết đồ thị - Bài 2+3: Các thuật toán tìm kiếm trên đồ thị (tt)
17 p | 47 | 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