Professional Documents
Culture Documents
Nhóm 4:
1. Lương Ngọc Duy (Nhóm trưởng)
2. Vũ Đình Du
3. Nguyễn Tiến Cường
4. Nguyễn Mạnh Dũng
5. Nguyễn Khánh Duy
NỘI DUNG CHÍNH
Định nghĩa 1.
Cây là đơn đồ thị vô hướng liên thông không có chu trình.
Đơn đồ thị vô hướng không có chu trình được gọi là rừng.
Như vậy, rừng là đồ thị mà mỗi thành phần liên thông của
nó là một cây
Ví dụ: Đồ thị G
T1 T2 T3
CÂY VÀ MỘT SỐ TÍNH CHẤT CƠ BẢN
• T là một cây;
• T không có chu trình và có n – 1 cạnh;
• T liên thông và có đúng n – 1 cạnh;
• T liên thông và mỗi cạnh của nó đều là cầu;
• Giữa hai đỉnh bất kỳ của T được nối với nhau bởi
đúng một đường đi đơn;
• T không chứa chu trình nhưng nếu cứ thêm vào nó
một cạnh sẽ thu được đúng một chu trình.
CÂY VÀ MỘT SỐ TÍNH CHẤT CƠ BẢN
Định nghĩa 2. Cho G là đơn đồ thị vô hướng liên thông.
Đồ thị con T của G là một cây khung của G (cây bao trùm)
nếu T thoả mãn hai điều kiện:
i) T là một cây;
ii) Tập đỉnh của T bằng tập đỉnh của G.
Cây khung:
2
7 8 11 12
1 3 5
6 9 10 13
4
XÂY DỰNG CÂY KHUNG
DỰA VÀO GIẢI THUẬT BFS
void Tree-BFS(u)
Begin
Bước 1 (Khởi tạo):
T= Ø; // Tập cạnh cây khung ban đầu
Queue = Ø; // Thiết lập hàng đợi ban đầu
Push(Queue, u); //Đưa u vào hàng đợi
chuaxet[u]=False; // Bật trạng thái đã xét của đỉnh u
Bước 2 (Lặp):
while (Queue Ø) do { // Lặp cho đến khi hàng đợi rỗng
s = Pop (Queue); // Lấy s ra khỏi hàng đợi
for each t Ke(s) do{ // Lặp trên danh sách Ke(s)
if(chuaxet[t]) then { //Nếu đỉnh t chuaxet
Push (Queue, t); //Đưa t hàng đợi
T= T ∪ (s,t); //Kết nạp s, t vào cây khung
chuaxet[t]=False; //Ghi nhận t đã xét
endif;
endfor;
endwhile;
Bước 3 (Trả lại kết quả):
if ((T < n-1) <Đồ thị không liên thông>;
else <Ghi nhận tập cạnh T của cây khung>;
End.
Đồ thị :
2
7 8 11 12
1 3 5
6 9 10 13
4
Các bước thực hiện của giải thuật được thực hiện như sau:
T.thái Queue:
Bước T =?
Tree-BFS(u) =?
1 1 T=Ø
2 2, 3, 4 T = T∪ {(1, 2), (1, 3), (1,4)}
3 3, 4 T=Ø
4 4, 5 T = T∪ (3, 5)
5 5 T=Ø
6 6, 7, 8, 9 T = T∪ {(5, 6), (5, 7), (5, 8), (5, 9)}
7 7, 8, 9 T=Ø
8 8, 9 T=Ø
9 9 T=Ø
10 10 T = T∪ (9, 10)
11 11, 12, 13 T = T∪ {(10, 11), (10, 12), (10, 13)}
12 12, 13 T=Ø
13 13 T=Ø
Kết luận
T={(1,2),(1,3),(1,4),(3,5),(5,6),(5,7),(5,8),(5,9),
(9,10),(10,11),(10,12),(10,13)}
Cây khung:
2
7 8 11 12
1 3 5
6 9 10 13
4
XÂY DỰNG CÂY KHUNG
CÓ TRỌNG SỐ NHỎ NHẤT
KRUSKAL PRIM
GIẢI THUẬT KRUSKAL
Begin
Bước 1 (khởi tạo):
T= Ø; //khởi tạo tập cạnh cây khung là Ø
d(H) = 0; // khởi tạo độ dài nhỏ nhất cây khung là 0
Bước 2 (Sắp xếp):
< sắp xếp các cạnh của đồ thị theo thứ tự giảm dần
theo trọng số>;
GIẢI THUẬT KRUSKAL
Bước 3 (Lặp):
while (T<n-1&&E ≠ Ø)do { // Lặp nếu E≠ Ø và T < n-1
e = <cạnh có độ dài nhỏ nhất>;
E = E \ {e}; //Loại cạnh e ra khỏi đồ thị
if (T ∪ {e} không tạo nên chu trình) {
T = ∪{e} ; // kết nạp e vào tập cạnh cây khung
d(H) = d(H) + d(e); // độ dài của tập cạnh cây
khung
endif;
GIẢI THUẬT KRUSKAL
Bước 4 (Trả lại kết quả):
if (T<n-1) <đồ thị không liên thông>;
else return (T, d(H));
End.
Ví dụ: Kiểm nghiệm giải thuật Kruskal trên đồ thị.
5 6 7
2 7 8 13
2 5 6 7
2 6 7 8
1 5
1 3 6 9 12
6
7 7
4 5
6 6 7 8
3
4 5 10 7 11
5 6
Thực hiện tuần tự các bước của giải thuật Kruskal
Bước 1: T = Ø ; D(T) = 0;
Bước 2. Sắp xếp các cạnh theo thứ tự tăng dần của trọng số:
Đầu Cuối Trọng Số Đầu Cuối Trọng Số
1 3 1 6 8 6
1 2 2 6 9 6
2 3 2 6 10 6
1 4 3 7 8 6
3 4 4 8 9 7
2 6 5 8 12 7
2 7 5 8 13 7
3 6 5 9 10 7
4 5 5 9 11 7
4 6 5 10 11 7
5 6 6 10 12 7
5 10 6 11 12 8
6 7 6 12 13 8
STT CẠNH ĐƯỢC XÉT T∪E
1 E \ (1,3) T = T ∪ (1,3); D(T)= 1
Bước 3 (Lặp): 2 E = E\(1,2) T = T ∪ (1,2); D(T)=1+2=3
3 E = E\(2,3) Tạo nên chu trình
4 E = E\(1,4) T = T ∪ (1,4); D(T)=3+3=6
5 E = E\(3,4) Tạo nên chu trình
6 E = E\(2,6) T = T ∪ (2,6); D(T)=6+5=11
7 E = E\(2,7) T = T ∪ (2,7); D(T)=11+5=16
8 E = E\(3,6) Tạo nên chu trình
9 E = E\(4,5) T = T ∪ (4,5); D(T)=16+5=21
10 E = E\(4,6) Tạo nên chu trình
11 E = E\(5,6) Tạo nên chu trình
12 E = E\(5,10) T = T ∪ (5,10); D(T)=21+6=27
13 E = E\(6,7) Tạo nên chu trình
14 E = E\(6,8) T = T ∪ (6,8); D(T)=27+6=33
15 E = E\(6,9) T = T ∪ (6,9); D(T)=33+6=39
16 E = E\(6,10) Tạo nên chu trình
17 E = E\(7,8) Tạo nên chu trình
18 E = E\(8,9) Tạo nên chu trình
19 E = E\(8,12) T = T ∪ (8,12); D(T)=39+7=46
20 E = E\(8,13) T = T ∪ (8,13); D(T)=46+7=53
21 E = E\(9,10) Tạo nên chu trình
22 E = E\(9,11) T = T ∪ (9,11); D(T) = 53+7 =60
Bước lặp kết thúc vì |T|> N-1 =12
Bước 4: Trả lại kết quả:
D(T) = 1 + 2 + 3 + 5 + 5 + 5 + 6 + 6 + 6 + 7 + 7 + 7 = 60
Cho đồ thị trọng số như hình 4.3. Khi đó các bước thực hiện
theo giải thuật PRIM như trong bảng sau:
5 7
2 7 8 13
2 7
5 6
1
1 3 6 9 12
6
7
3
4 5 10 11
5 6
THANKS FOR WATCHING