Các thuật toán Backtrack luôn đảm bảo tìm được chu trình Hamilton (nếu có) hoặc sẽ
kết thúc sau khi vét cạn các trường hợp mà đồ thị không có chu trình Hamilton, tuy nhiên
khả năng thực hiện hạn chế và thời gian chạy không khả thi trên các đồ thị lớn. Các thuật
toán Heuristic có sự cải tiến về khả năng thực hiện trên các đồ thị lớn và thời gian chạy
tuyến tính hoặc đa thức, tuy nhiên nó không đảm bảo rằng sẽ tìm được chu trình Hamilton,
mặc dù được thực hiện trên đồ thị Hamilton. Dưới đây là một số thuật toán Backtrack và
Heuristic xác định chu trình Hamilton trong đồ thị [5], [12], [38]
27 trang |
Chia sẻ: lavie11 | Lượt xem: 977 | Lượt tải: 0
Bạn đang xem trước 20 trang tài liệu Tóm tắt Luận án Chu trình Hamilton và chu trình dài nhất trong một số lớp đồ thị có tổng bậc lớn, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
ng ứng thay cho ).
Một đường đi là mở rộng (theo tập đỉnh) của đường đi nếu . Tương
tự, một chu trình là mở rộng của chu trình nếu .
Với , ta ký hiệu là đoạn đường chạy dọc theo từ đỉnh tới đỉnh . Như
vậy, nếu là các đỉnh cuối của thì cũng chính là . Ngoài ra, | | quy ước là số
đỉnh nằm trên đoạn đường con này.
Giả sử chu trình . Ta quy định một chiều quay ⃗⃗ ⃗ theo
thứ tự chỉ số các đỉnh (chỉ số được lấy theo ). Với đỉnh , ký hiệu
lần
lượt là đỉnh liền trước và liền sau của theo chiều quay đã định. Với tập đỉnh thì
,
. Với số nguyên dương , ký hiệu
5
và
. Ta ký hiệu đoạn đường trên bắt
đầu từ một đỉnh và kết thúc tại theo chiều quay đã quy định bởi ⃗⃗ ⃗ , đoạn
đường đó theo chiều ngược lại ký hiệu là ⃖⃗⃗⃗ . Nếu là một thành phần liên thông của
, ký hiệu là tập hợp các láng giềng của trên . Một dãy cung ngoại biên nối
hai đỉnh trên là một đường đi có các đỉnh cuối là 2 đỉnh đó và các đỉnh trong thuộc
. Đặc biệt, một cạnh nối 2 đỉnh trên cũng là một dãy cung ngoại biên.
Đôi khi ta cũng thường không viết dấu phẩy (,) ngăn cách giữa các đỉnh của một chu
trình hoặc một đường đi. Ví dụ, viết thay cho .
1.3. Chu trình Hamilton
Chu trình đi qua mọi đỉnh của đồ thị, mỗi đỉnh đi qua đúng một lần, gọi là chu trình
Hamilton. Đồ thị có chu trình Hamilton được gọi là đồ thị Hamilton. Tương tự, đường đi
qua mọi đỉnh của đồ thị, mỗi đỉnh đi qua đúng một lần, gọi là đường Hamilton và đồ thị có
đường Hamilton gọi là đồ thị nửa Hamilton.
Lịch sử phát sinh đồ thị Hamilton được xuất phát từ trò chơi đố vui của William
Rowan Hamilton vào năm 1859. Chu trình Hamilton có nhiều ứng dụng trong thực tế, ví dụ
như trong bài toán người bán hàng, lập kế hoạch, hay trong thiết kế vi mạch, thiết kế đường
truyền trong mạng Cho đến nay, vấn đề chu trình Hamilton vẫn còn là mở và trở thành
một vấn đề trung tâm của lý thuyết đồ thị với rất nhiều công trình nghiên cứu. Thông qua ba
bài tổng quan của Ronald J. Gould trong [25], [26], [27] thì có thể thấy rằng trong vòng 20
năm trở lại đây có khoảng 400 bài báo khoa học nghiên cứu về chu trình Hamilton được
đăng tải trên các tạp chí khoa học quốc tế có uy tín hàng đầu.
Trong luận án sẽ nghiên cứu chu trình Hamilton theo hướng sau:
Nghiên cứu bài toán trên lớp đồ thị có tổng bậc và
lớn.
Nghiên cứu độ phức tạp của bài toán và xác định ranh giới để bài toán chuyển
từ lớp sang lớp .
Xây dựng thuật toán thời gian đa thức để xác định chu trình Hamilton trong một số
lớp đồ thị đã khảo sát mà bài toán thuộc lớp .
1.3.1. Độ phức tạp của bài toán
Bài toán đã được chứng minh trong [23] là các bài toán .
(Hamiltonian Cycle Problem)
Instance: Đồ thị .
Question: có là đồ thị Hamilton?
Một số tác giả đã nghiên cứu đến độ phức tạp của bài toán trên những lớp đồ thị
đặc biệt, chẳng hạn như trong [37] đánh giá độ phức tạp trên lớp đồ thị có hướng phẳng, hay
6
trong [3] nghiên cứu trên hai lớp đồ thị dạng lưỡng phân... Trong [15], các tác giả đã chỉ ra
rằng bài toán vẫn còn là bài toán trên lớp đồ thị
với mọi :
Định lý 1.1 [15, Định lý 16].
là bài toán với mọi .
Kết quả trên là một tiền đề quan trọng để tác giả tiếp tục nghiên cứu đến độ phức tạp
của bài toán trên các lớp đồ thị có tổng bậc và
lớn.
1.3.3. Một số điều kiện đủ đối với bậc của đỉnh
Các kết quả nghiên cứu về chu trình Hamilton hầu hết tập trung ở điều kiện đủ, đặc
biệt là điều kiện đủ đối với bậc của đỉnh. Ta bắt đầu bằng với một kết quả của Dirac:
Định lý 1.4 [17]. Nếu đồ thị với đỉnh và bậc mỗi đỉnh đều không nhỏ hơn
thì là
đồ thị Hamilton.
Định lý Dirac là trường hợp riêng của Định lý Ore.
Định lý 1.5 [36]. Nếu đồ thị với đỉnh và thì là đồ thị Hamilton.
Với đồ thị tough, mở rộng cho Định lý Ore, Jung có kết quả sau:
Định lý 1.6 [29]. Cho là đồ thị 1-tough với đỉnh và . Khi đó,G là đồ thị
Hamilton.
Mở rộng kết quả cho có:
Định lý 1.7 [18]. Cho G là đồ thị 1-tough với đỉnh và
. Khi đó, là đồ
thị Hamilton.
Với đồ thị -liên thông, Bondy đưa ra kết quả tổng quát cho như sau:
Định lý 1.8 [11]. Nếu là đồ thị -liên thông thỏa mãn
thì là đồ thị
Hamilton.
Liên quan đến khoảng cách có kết quả sau:
Định lý 1.10 [32, Định lý 5]. Cho là đồ thị 2-liên thông với đỉnh thỏa mãn
. Khi đó xảy ra một trong hai trường hợp sau:
1. là đồ thị Hamilton.
2. là số lẻ và ̅
̅
̅
.
1.3.4. Một số thuật toán xác định chu trình Hamilton
Các nghiên cứu về thuật toán xác định chu trình Hamilton được tiếp cận theo các
hướng sau:
Thuật toán Backtrack (Quay lui).
Thuật toán Heuristic.
Thuật toán tìm kiếm chu trình Hamilton cho các lớp đồ thị đặc biệt.
7
Các thuật toán Backtrack luôn đảm bảo tìm được chu trình Hamilton (nếu có) hoặc sẽ
kết thúc sau khi vét cạn các trường hợp mà đồ thị không có chu trình Hamilton, tuy nhiên
khả năng thực hiện hạn chế và thời gian chạy không khả thi trên các đồ thị lớn. Các thuật
toán Heuristic có sự cải tiến về khả năng thực hiện trên các đồ thị lớn và thời gian chạy
tuyến tính hoặc đa thức, tuy nhiên nó không đảm bảo rằng sẽ tìm được chu trình Hamilton,
mặc dù được thực hiện trên đồ thị Hamilton. Dưới đây là một số thuật toán Backtrack và
Heuristic xác định chu trình Hamilton trong đồ thị [5], [12], [38]:
Bảng 1.1. Một số thuật toán Backtrack và Heuristic xác định chu trình Hamilton
Thuật toán Tác giả Loại
Pósa Pósa Heuristic
UHC Angluin and Valiant Heuristic
HAM Bollobas, Fenner and Frieze Heuristic
SparseHam Frieze Heuristic
HideHam Broder, Frieze and Shamir Heuristic
DB2 Brunacci Heuristic
LongPath Kocay and Li Heuristic
LinearHam Thomason Heuristic
Snakes and Ladders
P. Baniasadi, V. Ejov, J.A. Filar, M.
Haythorpe, S. Rossomakhine
Heuristic
MultiPath Kocay Backtrack
MultiPath cải tiến Andrew Chalaturnyk Backtrack
KTC Shufelt and Berliner Backtrack
Một số tác giả khác đã nghiên cứu tới việc xây dựng các thuật toán xác định chu trình
Hamilton trong các lớp đồ thị đặc biệt. Các thuật toán này là chính xác và đảm bảo tìm được
chu trình Hamilton, thời gian đa thức, tuy nhiên nhược điểm là không thực hiện được trên
đồ thị tổng quát. Gần đây, các tác giả trong [28] đã đưa ra thuật toán thời gian
trên đồ thị Circular-Arc, trong [22] sử dụng phương pháp “tham lam” và 2-matching để xây
dựng thuật toán thời gian xác định chu trình Hamilton trong đồ thị ngẫu
nhiên Với đồ thị Ore (lớp đồ thị ), một số tác giả cũng đưa ra thuật toán đa thức để
xác định chu trình Hamilton, chẳng hạn như thuật toán do Albertson đề xuất [4]
1.4. Bao đóng đồ thị
Bổ đề 1.2 [10]. Giả sử đồ thị có bậc và hai đỉnh không kề nhau thỏa mãn
. Khi đó, là đồ thị Hamilton khi và chỉ khi là đồ thị Hamilton.
Khái niệm bao đóng của đồ thị được Bondy và Chvátal đưa ra lần đầu tiên trong [10].
Bao đóng của đồ thị , ký hiệu bởi là đồ thị thu được từ bằng cách bổ sung thêm
các cạnh nối các cặp đỉnh không kề nhau có tổng bậc không nhỏ hơn , quá trình này được
thực hiện cho đến khi nào không còn cặp đỉnh không kề nhau mà có tổng bậc không nhỏ
hơn nữa. Bao đóng của một đồ thị luôn xác định duy nhất, không phụ thuộc vào thứ tự
cạnh mới được thêm vào [2].
8
Hình 1.5. Quá trình tạo bao đóng đồ thị.
Trong việc bổ sung lần lượt các cạnh mới để tạo bao đóng , ta thực hiện việc gán
nhãn tăng dần theo thứ tự các cạnh được bổ sung bằng mảng . Trước hết, [ ] với
mọi cạnh và đặt . Khi cạnh mới đầu tiên được bổ sung, ta gán [ ]
, và thu được đồ thị mới . Quá trình được thực hiện liên tục cho đến khi
không có cạnh nào được bổ sung nữa và thu được đồ thị cuối cùng là . Rõ ràng
là: .
Thuật toán 1.2. Xây dựng đồ thị bao đóng và gán nhãn cho các cạnh.
Input: Đồ thị .
Output: Đồ thị và các cạnh được gán nhãn.
Procedure Construct_Cl
Begin
For each do
Begin
[ ] ;
For each do If Then [ ] [ ] ;
End;
For each do [ ] ;
;
Repeat
Stop True;
For each do
For each do
If and [ ] [ ] Then
Begin
Stop False; ;
; [ ] ;
[ ] [ ] ; [ ] [ ] ;
End;
Until Stop;
End;
Nếu là một đồ thị con của , ta đặt: [ ] [ ] .
9
Mệnh đề 1.2. Nếu thì là đồ thị Hamilton khi và chỉ khi là đồ thị
Hamilton.
Thuật toán 1.3. Biến đổi chu trình Hamilton của đồ thị bao đóng.
Input: là một chu trình Hamilton của .
Output: Một chu trình Hamilton của đồ thị .
Procedure TransformCycle( )
Begin
While ( [ ] ) do
Begin
Tìm [ ] [ ];
Tìm và [ ] [ ] [ ];
;
Đánh số lại các đỉnh trên theo thứ tự mới:
;
End;
End;
1.6. Chu trình trong đồ thị có tập láng giềng lớn
Định lý 1.20 [8]. Nếu là đồ thị 2-liên thông và thì .
Định lý 1.21 [8]. Nếu là đồ thị 1-tough và thì .
Bauer, Fan, Veldman đã đưa ra Giả thuyết quan trọng sau:
Giả thuyết 1.3 [8, Giả thuyết 27]. Nếu là đồ thị 1-tough và thì
.
1.7. Kết luận Chƣơng 1
Như vậy, chương này đầu tiên đã giới thiệu các khái niệm cơ bản nhất của lý thuyết đồ
thị cần thiết cho luận án. Kế đến giới thiệu các Bổ đề, Thuật toán cơ bản, đặc biệt là bao
đóng đồ thị làm nền tảng cơ sở quan trọng cho các chứng minh trong luận án. Cuối cùng
trình bày tổng quan về chu trình trong đồ thị, tập trung trọng tâm tới chu trình Hamilton với
các vấn đề nêu ra là: độ phức tạp bài toán của , một số điều kiện cần và đủ cho một đồ
thị là Hamilton, một số thuật toán để xác định chu trình Hamilton trong đồ thị. Ngoài ra, chu
trình Dominating, chu trình trong đồ thị có tập láng giềng lớn cũng được đề cập tới.
Định lý 1.1 của các tác giả trong [15] đã chỉ ra rằng bài toán trong lớp đồ thị
vẫn còn là bài toán với mọi là tiền đề để tác giả tiếp tục nghiên
cứu bài toán cho lớp đồ thị tổng quát hơn theo các giá trị (với tổng quát) và
trong Chương 2 và Chương 3. Giả thuyết 1.3 của các tác giả trong [8] đưa ra đánh giá về độ
10
dài của chu trình dài nhất hiện nay vẫn còn là vấn đề mở, trong Chương 4 tác giả sẽ đưa ra
một chứng minh cho Giả thuyết này.
CHƢƠNG 2. MỘT SỐ LỚP ĐA THỨC CỦA BÀI TOÁN
2.1. Giới thiệu bài toán và
Với số nguyên dương và số thực ta xét bài toán tổng quát sau:
Instance: Đồ thị thỏa mãn
.
Question: có là đồ thị Hamilton?
Với , mở rộng cho bài toán khi ta chỉ xét tới các cặp đỉnh khoảng cách 2:
Instance: Đồ thị thỏa mãn
.
Question: có là đồ thị Hamilton?
Trường hợp thì và chính là bài toán trong trường hợp tổng quát.
2.2. Độ phức tạp của bài toán và
Từ Định lý 1.1, dễ dàng suy ra Hệ quả sau:
Hệ quả 2.1. là bài toán .
Định lý 2.1. là bài toán .
Định lý 2.2. là bài toán .
Như vậy, với thì bài toán vẫn còn là bài toán .
Giả thuyết 2.1. Với mọi số nguyên dương thì bài toán thuộc lớp .
2.3. Độ phức tạp của bài toán
2.3.1. Một số kết quả với
Từ Định lý 1.4 (Dirac) và Định lý 1.5 (Ore) ta hiển nhiên có:
Hệ quả 2.2. và là các bài toán thuộc lớp .
Từ Định lý 1.8 (Bondy) cho trường hợp , ta có:
Hệ quả 2.3. Mọi đồ thị 2-liên thông thỏa mãn
là đồ thị Hamilton.
Điều kiện
là tốt nhất có thể theo nghĩa là tồn tại vô hạn đồ thị 2-liên thông
thỏa mãn
nhưng không Hamilton, chẳng hạn các đồ thị ̅ với .
11
Hệ quả 2.4.
là bài toán thuộc lớp .
Hệ quả 2.5. là bài toán thuộc lớp .
Với kết quả của Bondy (Định lý 1.8) cho trường hợp thì không thể kết luận cho
độ phức tạp của bài toán vì điều kiện 3-liên thông không phải là điều kiện cần của một
đồ thị Hamilton. Ta sẽ chứng minh cũng là bài toán thuộc lớp bằng việc
khảo sát lớp đồ thị thỏa mãn .
Định lý 2.3. Cho đồ thị 2-liên thông thỏa mãn . Khi đó, hoặc là đồ thị
Hamilton, hoặc và có cấu trúc thuộc một trong 3 dạng sau:
1. Dạng 1: Tồn tại | | sao cho . (Hình 2.1)
Hình 2.1. Đồ thị Dạng 1, Định lý 2.3.
2. Dạng 2: có ba đồ thị con đầy đủ và một đỉnh sao cho tồn tại
, , và . Hơn
nữa, tồn tại ba đỉnh , , sao cho
. Ngoài ra, đỉnh có thể kề với bất kỳ đỉnh còn lại nào. (Hình 2.2)
Hình 2.2. Đồ thị Dạng 2, Định lý 2.3.
3. Dạng 3: có ba đồ thị con đầy đủ | | | | | | và tồn tại các
đỉnh với sao cho
. (Hình 2.3)
12
Hình 2.3. Đồ thị Dạng 3, Định lý 2.3.
Hệ quả 2.6. Mọi đồ thị 2-liên thông thỏa mãn và là đồ thị Hamilton.
Từ thuật toán đa thức nhận biết 3 dạng đồ thị đặc biệt không Hamilton trong Định lý
2.3, ta có:
Định lý 2.4. là bài toán thuộc lớp .
2.4. Bài toán
Từ Định lý 1.10, để đánh giá được độ phức tạp của bài toán ta sẽ đưa ra
thuật toán thời gian sau:
Thuật toán 2.4. Nhận biết đồ thị thuộc dạng: ̅
̅
̅
.
Input: Đồ thị .
Output: Is_Graph4 = True nếu ̅
̅
̅
,
ngược lại, Is_Graph4 = False.
Chương trình:
Function Boolean Is_Graph4
Begin
If ( ) Then Return False;
Tính bậc các đỉnh của ;
;
For each do
If (
) Then ;
If (| |
) and ( là tập đỉnh độc lập) Then
Return True
Else Return False;
End;
Hệ quả 2.7.
là bài toán thuộc lớp .
Hệ quả 2.8. là bài toán thuộc lớp .
13
2.5. Kết luận Chƣơng 2
Bài toán đã được đánh giá độ phức tạp trong [15] và Chương này tác giả đã tiếp
tục nghiên cứu mở rộng theo hai bài toán (với nguyên dương tổng quát) và .
Các kết quả đạt được như sau:
Với thì các bài toán vẫn còn là bài toán .
Với thì các bài toán và thuộc lớp .
Như vậy, có thể nói rằng Giả thuyết 2.1 đã được tác giả giải quyết đến trường hợp
, với thì vẫn còn là vấn đề mở.
Dựa trên các kết quả đạt được và Hệ quả 2.6, tác giả đưa ra Giả thuyết thứ hai:
Giả thuyết 2.2. Với mọi số nguyên dương , nếu đồ thị 2-liên thông thỏa mãn và
thì là đồ thị Hamilton.
CHƢƠNG 3. THUẬT TOÁN ĐA THỨC XÁC ĐỊNH CHU TRÌNH
HAMILTON TRONG ĐỒ THỊ
VÀ
Chương này tác giả sẽ đề xuất các thuật toán đa thức xác định chu trình Hamilton cho
hai lớp đồ thị
và
. Thêm vào đó, tác giả đề xuất việc sử dụng bao
đóng đồ thị để mở rộng lớp đồ thị thực hiện thuật toán. Cuối cùng, tác giả tiến hành thực
nghiệm trên các đồ thị có số đỉnh lớn để cho thấy tính hiệu quả và khả thi thực hiện của các
thuật toán đề xuất.
3.1. Thuật toán cho lớp đồ thị
Bổ đề 3.1. Cho là đồ thị thỏa mãn
và là đồ thị Hamilton. là một chu trình
bất kỳ trong , là một thành phần liên thông của . Giả sử các đỉnh của
được đánh số theo một chiều quay trên lần lượt là . Nếu có không quá
đỉnh thì sẽ xảy ra một trong các trường hợp sau:
1. Tồn tại sao cho
.
2. Tồn tại
với .
3. Tồn tại , khi đó kề với tất cả các đỉnh
,
4. Tồn tại sao cho
.
a. Thuật toán 3.1. Xác định chu trình Hamilton cho đồ thị
.
Input: Đồ thị 2-liên thông thỏa mãn
.
Output: Chu trình Hamilton của nếu là đồ thị Hamilton, hoặc trả lời không có
chu trình Hamilton.
Procedure Hamilton2*;
14
BEGIN
// Kiểm tra không là đồ thị Hamilton
1: If ( ̅
̅
̅
) Then
2: Begin
3: Thông báo không có chu trình Hamilton;
4: Kết thúc;
5: End;
// Trường hợp là đồ thị Hamilton
6: Tìm một chu trình tùy ý của đồ thị ;
// Vòng lặp mở rộng tập đỉnh của
7: While | | Do
8: Begin
9: Tìm một thành phần liên thông của – ;
10: Đánh số các đỉnh của lần lượt là ;
// Mở rộng chu trình theo 4 trường hợp
11: If tồn tại
Then
12: Begin
13: Tìm sao cho
;
14: Tìm một đường đi nối x với y trong ;
15: Thay thế thành chu trình mới
⃗⃗ ⃗ ;
16: End
17: Else If tồn tại
Then
18: Begin
19: Tìm sao cho ;
20: Tìm một đường đi nối x với y trong ;
21: Thay thế thành chu trình mới ⃖⃗⃗⃗
⃗⃗ ⃗ ;
22: End
23: Else If tồn tại Then
24: Begin
25: Chọn tùy ý và tìm sao cho ;
26: Tìm một đường đi nối x với y trong ;
27: Thay thế thành chu trình mới ⃖⃗⃗⃗
⃗⃗ ⃗ ;
28: End
29: Else
30: Begin
31: Tìm
và tìm sao cho ;
32: Tìm một đường đi nối x với y trong ;
33: Thay thế thành chu trình
⃗⃗ ⃗
⃗⃗ ⃗ ;
34: End;
35: End;
END;
Thuật toán 3.1 cần không quá phép toán thực hiện.
15
3.2. Thuật toán cho lớp đồ thị
Ý tưởng của thuật toán là trong trường hợp 2-liên thông thì xây dựng một chu trình
tùy ý trong với thời gian đa thức, sau đó mở rộng cho đến khi đủ đỉnh bằng cách
nối thêm một số cạnh cho cặp đỉnh không kề nhau có tổng bậc không nhỏ hơn , đồng thời
kết hợp với việc gán nhãn cho các cạnh (được trình bày trong phần 1.4). Cuối cùng, ta sử
dụng Thuật toán 1.3 (TransformCycle) để tìm chu trình Hamilton cho đồ thị ban đầu từ .
a. Thuật toán 3.2. Xác định chu trình Hamilton cho đồ thị
Input: Đồ thị 2-liên thông thỏa mãn
.
Output: Chu trình Hamilton của .
Procedure Hamilton3;
BEGIN
// Gán nhãn bằng 1 cho tất cả các cạnh của
1: For each in do [ ] ;
2: ;
3: Tìm một chu trình tùy ý của đồ thị ;
4: While | | Do
5: Begin
6: Đánh số lại các đỉnh của ;
7: Tìm một thành phần liên thông của – ;
8: Tìm tập đỉnh ;
// Mở rộng theo 3 trường hợp
9: If tồn tại Then
10: Begin
11: Tìm sao cho ;
12: Tìm một đường đi nối x với y trong ;
13: Thay thế thành chu trình mới ⃗⃗ ⃗ ;
14: End
15: Else If tồn tại Then
16: Begin
17: Tìm sao cho ;
18: Tìm một đường đi nối x với y trong ;
19: Thay thế thành chu trình mới ⃖⃗⃗⃗ ⃗⃗ ⃗ ;
20: End
21: Else
22: Begin
23: Tìm hai đỉnh bất kỳ thuộc ;
// Bổ sung cạnh mới cho đồ thị và gãn nhãn
24: ;
25: ;
26: [ ] ;
27: Tìm sao cho ;
16
28: Tìm một đường đi nối x với y trong ;
29: Thay thế thành chu trình mới ⃖⃗⃗⃗ ⃗⃗ ⃗ ;
30: End;
31: End;
// Biến đổi thành chu trình Hamilton của ban đầu
32: TransformCycle( );
END;
Thuật toán 3.2 cần không quá phép toán thực hiện.
3.3. Sử dụng bao đóng cho các lớp đồ thị có tổng bậc lớn
Theo Mệnh đề 1.2 thì là đồ thị Hamilton khi và chỉ khi là đồ thị Hamilton.
Trong đồ thị bao đóng , bậc của mỗi đỉnh đều không nhỏ hơn bậc của đỉnh tương ứng
trong đồ thị (Vì ), do đó các điều kiện về tổng bậc
lớn trong đồ thị bao
đóng sẽ có nhiều khả năng thỏa mãn hơn so với đồ thị ban đầu. Sau khi tìm được
một chu trình Hamilton trong đồ thị , sử dụng Thuật toán 1.3 sẽ tìm được một chu
trình Hamilton trong đồ thị ban đầu từ chu trình . Do đó, tác giả đưa ra đề xuất sau:
Hình 3.1. Sơ đồ thuật toán xác định chu trình Hamilton sử dụng bao đóng đồ thị
17
Đề xuất 3.1. Sử dụng bao đóng đồ thị kết hợp với các thuật toán xác định chu trình
Hamilton trong các lớp đồ thị có tổng bậc lớn để có thể thực hiện cho lớp đồ thị tổng quát
hơn.
Như vậy, thay vì việc không áp dụng được thuật toán cho đồ thị ban đầu, khi chuyển
sang đồ thị bao đóng thì khả năng áp dụng được thuật toán sẽ cao hơn. Với Thuật toán 3.1
và 3.2 khi sử dụng bao đóng đồ thị như sơ đồ thuật toán trên cũng chỉ cần không quá
phép toán thực hiện.
Với các đồ thị có tổng bậc lớn thì số cạnh cũng lớn nên khi chạy chương trình cho
Thuật toán tìm chu trình Hamiltton trên đồ thị bao đóng thì thời gian tăng không đáng kể.
3.4. Chƣơng trình thực nghiệm
Phần này sẽ xây dựng chương trình thực nghiệm cho hai thuật toán 3.1 và 3.2 mà tác
giả đã đề xuất để xác định chu trình Hamilton cho lớp đồ thị
và
.
3.4.1. Giới thiệu chƣơng trình
Hình 3.2. Sơ đồ khối thực hiện chương trình
Chương trình thực nghiệm sẽ được xây dựng theo sơ đồ khối đưa ra trong Hình 3.2 và
phần thực hiện Tìm Chu trình Hamilton theo thuật toán tƣơng ứng sẽ được đo thời gian.
Tác giả xây dựng hai chương trình thực nghiệm xác định chu trình Hamilton như sau:
Bảng 3.1. Các chương trình thực nghiệm xác định chu trình Hamilton
Chƣơng trình Lớp đồ thị Thuật toán áp dụng Thời gian
Chương trình 1
. Thuật toán 3.1
Chương trình 2
. Thuật toán 3.2
18
Việc xác định giá trị hoặc
cần thuật toán nên việc kiểm tra một đồ thị bất
kỳ có thuộc lớp
hoặc
chỉ mất thời gian là , do đó Chương trình
có thể nhận dữ liệu đầu vào là đồ thị tổng quát và thực hiện khả thi với các đồ thị lớn.
Chương trình sử dụng ngôn ngữ lập trình C# và được tiến hành thực nghiệm trên máy
tính sử dụng Hệ điều hành Windows7, bộ vi xử lý Core i3 2.53 GHz, RAM 8GB.
3.4.2. Bộ dữ liệu đầu vào
Do không có đồ thị mẫu và cũng chưa có tác giả nào tiến hành thực nghiệm việc tìm
chu trình Hamilton trên những lớp đồ thị
và
nên tác giả sẽ xây dựng
hai bộ dữ liệu được sinh ngẫu nhiên gồm các đồ thị 2-liên thông thỏa mãn điều kiện đầu vào
tương ứng của Thuật toán 3.1 hoặc Thuật toán 3.2 để thực nghiệm.
Bộ dữ liệu 1 gồm các đồ thị thỏa mãn điều kiện
, nhưng không thỏa mãn
điều kiện
. Bộ dữ liệu 2 gồm các đồ thị thỏa mãn điều kiện
, nhưng
không thỏa mãn điều kiện
.
Bảng 3.2. Danh sách các đồ thị được tiến hành thực nghiệm
Số đỉnh
( )
Đồ thị
Bộ dữ liệu 1
(
)
Bộ dữ liệu 2
(
)
1000 S2sao-1000 S3-1000
2000 S2sao-2000 S3-2000
3000 S2sao-3000 S3-3000
4000 S2sao-4000 S3-4000
5000 S2sao-5000 S3-5000
6000 S2sao-6000 S3-6000
7000 S2sao-7000 S3-7000
8000 S2sao-8000 S3-8000
9000 S2sao-9000 S3-9000
10000 S2sao-10000 S3-10000
3.4.3. Đánh giá hiệu năng
Bảng 3.3. Thống kê thời gian chạy chương trình khi sử dụng Thuật toán 1.1
Chƣơng trình 1 Chƣơng trình 2
Đồ thị Thời gian (s) Đồ thị Thời gian (s)
S2sao-1000 2.467 S3-1000 2.283
S2sao-2000 19.664 S3-2000 17.945
S2sao-3000 64.895 S3-3000 61.586
19
S2sao-4000 154.620 S3-4000 141.135
S2sao-5000 300.194 S3-5000 264.959
S2sao-6000 525.644 S3-6000 476.623
S2sao-7000 836.379 S3-7000 754.716
S2sao-8000 1249.134 S3-8000 1122.091
S2sao-9000 1780.245 S3-9000 1618.704
S2sao-10000 2416.288 S3-10000 2200.797
Thuật toán 3.1 và Thuật toán 3.2 đều có điểm chung là sử dụng Thuật toán 1.1 để xây
dựng một chu trình ban đầu, sau đó mở rộng cho đến khi có đủ đỉnh do đó độ dài
của chu trình ban đầu sẽ có ảnh hưởng rất lớn đến thời gian chạy chương trình.
Thuật toán 1.1 tìm một chu trình bất kỳ trong đồ thị làm chu trình khởi tạo ban đầu,
tuy nhiên độ dài của là thường là nhỏ. Để tăng tốc độ thực hiện cho chương trình thì có
thể sử dụng một số phương pháp Heuristic thay cho Thuật toán 1.1 để chu trình ban đầu
có độ dài lớn, khi đó số vòng lặp mở rộng chu trình sẽ giảm đáng kể.
Đề xuất 3.2. Tìm một đường đi dài nhất có thể, sau đó tìm cặp đỉnh thuộc sao
cho và đoạn đường dài nhất có thể. Khi đó, ta có một chu trình độ dài lớn là
;
Đề xuất trên có thể được thực hiện bởi Thuật toán sau.
Thuật toán 3.3. Xác định một chu trình có độ dài lớn trong đồ thị 2-liên thông
Input: Đồ thị 2-liên thông .
Output: Một chu trình của có độ dài lớn.
Procedure Create_Long_Cycle()
Begin
Tìm một cạnh ;
;
Stop = False;
While Not(Stop) Do
Begin
Stop = True;
For each Do
If và ( là một đỉnh cuối của ) Then
Begin
; ;
Stop = False;
End;
End;
Found = False; Length = ;
20
While Not(Found) Do
Begin
If tồn tại sao cho | | = Length và Then
Begin
; Found = True;
End
Else Length = Length – 1;
End;
End;
Thay thế Thuật toán 1.1 bởi Thuật toán 3.3 để tìm chu trình khởi tạo ban đầu , tác giả
đã cải tiến được đáng kể thời gian chạy hai chương trình.
Bảng 3.4. Tổng hợp thời gian chạy Chương trình 1 trước và sau khi cải tiến.
Đồ thị
Chƣơng trình 1 Chƣơng trình 1 cải tiến
Độ dài
ban đầu
Thời gian
(s)
Độ dài ban
đầu
Thời gian
(s)
S2sao-1000 4 2.467 999 0.032
S2sao-2000 4 19.664 1997 0.098
S2sao-3000 4 64.895 2988 0.653
S2sao-4000 4 154.620 3980 1.738
S2sao-5000 4 300.194 4997 0.482
S2sao-6000 4 525.644 5990 1.996
S2sao-7000 4 836.379 6987 3.470
S2sao-8000 4 1249.134 7951 16.556
S2sao-9000 4 1780.245 8997 1.496
S2sao-10000 4 2416.288 9986 7.569
Bảng 3.5. Tổng hợp thời gian chạy Chương trình 2 trước và sau khi cải tiến.
Đồ thị
Chƣơng trình 2 Chƣơng trình 2 cải tiến
Độ dài
ban đầu
Thời gian
(s)
Độ dài
ban đầu
Thời gian
(s)
S3-1000 3 2.283 994 0.065
S3-2000 3 17.945 1998 0.123
S3-3000 3 61.586 2992 0.436
S3-4000 3 141.135 3995 0.639
S3-5000 3 264.959 4997 0.799
S3-6000 3 476.623 5997 1.418
S3-7000 3 754.716 6995 1.753
S3-8000 4 1122.091 7998 2.192
S3-9000 3 1618.704 8998 2.569
S3-10000 3 2200.797 9998 3.373
21
Phân tích sự ảnh hưởng của độ dài chu trình khởi tạo ban đầu đối với thời gian chạy
chương trình, tác giả chọn đồ thị S3-2000 để tiến hành thực nghiệm (bằng Chương trình 2).
Kết quả thực nghiệm được đưa ra trong Bảng 3.6 và Hình 3.3 như sau:
Bảng 3.6. Thống kê thời gian chạy Chương trình 2 trên đồ thị S3-2000 theo độ dài chu trình khởi
tạo ban đầu.
Độ dài ban đầu Thời gian (s)
3 17.945
200 14.802
400 12.266
600 10.095
800 8.588
1000 6.737
1200 5.380
1400 4.391
1600 2.893
1800 1.587
1998 0.123
Hình 3.3. Biểu đồ thời gian chạy Chương trình 2 trên đồ thị S3-2000 theo độ dài chu trình khởi tạo
ban đầu.
3.5. Kết luận Chƣơng 3
Chương này đã đề xuất hai thuật toán chính xác để xác định chu trình Hamilton trong
lớp đồ thị
và
. Hai thuật toán này đã được đánh giá trên phương diện
lý thuyết là không quá phép toán thực hiện và tác giả cũng đã tiến hành thực nghiệm
trên các đồ thị lớn từ 1000 đỉnh đến 10000 đỉnh. Kết quả thực nghiệm đã cho thấy tính khả
thi, hiệu quả và ý nghĩa thực tiễn của các thuật toán do tác giả đề xuất.
22
Tác giả đã tiến hành thực nghiệm theo hai chương trình khác nhau và đánh giá được
yếu tố ảnh hưởng chính đến thời gian chạy chương trình là độ d
Các file đính kèm theo tài liệu này:
- tt_chu_trinh_hamilton_va_chu_trinh_dai_nhat_trong_mot_so_lop_do_thi_co_tong_bac_lon_3762_1920000.pdf