Giải thuật tìm phủ tối thiểu (C2)
Input: tập phụ thuộc hàm F
Output: G là 1 phủ tối thiểu của F
Bước 1: G:=F, tất cả FD đều được biến đổi thành thuộc tính đơn bên phía phải
Bước 2: Xóa tất cả thuộc tính dư thừa khỏi phía trái của FD trong G
Bước 3: Xóa tất cả các FD dư thừa khỏi G Return G
Ví dụ
Ví dụ
Cho tập thuộc tính ABCDEFGH, và tập phụ thuộc hàm F ABHC AD CE BGHF FAD EF BHE 64
Giải thuật tìm phủ tối thiểu (C2)Giải thuật tìm phủ tối thiểu (C2) Giải thuật tìm phủ tối thiểu (C2)
Ví dụ (tt)
Ví dụ (tt)
Bước 1: xác định G với tất cả các FD có vế phải thuộc tính đơn ABHC AD CE BGHF FA FD EF BHE 65
Giải thuật tìm phủ tối thiểu (C2)Giải thuật tìm phủ tối thiểu (C2) Giải thuật tìm phủ tối thiểu (C2)
Bước 2: Xóa tất cả thuộc tính dư thừa khỏi phía trái của FD trong G
Xét ABHC
Vì A+= {AD}, B+={B}, H+={H}
(AB)+ = {ABD}, (AH)+={AHD} (BH)+={BHEFAD}
FD ABHC không dư thừa vế trái Xét BGHF
Vì B+={B}, H+={H}, G+={G}, (GH)+={GH} (BG)+={BG}, (BH)+={BHEFAD}
BGH F có G dư thừa
66
Giải thuật tìm phủ tối thiểu (C2)Giải thuật tìm phủ tối thiểu (C2) Giải thuật tìm phủ tối thiểu (C2)
Bước 2: Xóa tất cả thuộc tính dư thừa khỏi phía trái của FD trong G ABHC AD CE BHF (Loại bỏ G) FA FD EF BHE 67
Giải thuật tìm phủ tối thiểu (C2)Giải thuật tìm phủ tối thiểu (C2) Giải thuật tìm phủ tối thiểu (C2)
Bước 3: Xóa tất cả các FD dư thừa khỏi G
Loại bỏ FD FD (vì FA, AD)
Loại bỏ FD BHF (vì BH E, EF) G còn lại các FD sau:
G= {ABHC, AD, CE, FA, EF, BHE} BHE}
G là phủ tối thiểu của F
68
Giải thuật tìm phủ tối thiểu (C2)Giải thuật tìm phủ tối thiểu (C2) Giải thuật tìm phủ tối thiểu (C2)