Tài liệu Bài giảng Kỹ thuật phân tích giải thuật: Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................ Trang 1
1. Mөc tiêu
2. KiӃn thӭc cѫ bҧn cҫn có ÿӇ hӑc chѭѫng này
3. Tài liӋu tham khҧo có liên quan ÿӃn chѭѫng
4. Nӝi dung:
I.1 - Sӵ cҫn thiӃt phҧi phân tích giҧi thuұt.
I.2 - Thӡi gian thӵc hiӋn cӫa giҧi thuұt.
I.3 - Tӹ suҩt tăng và ÿӝ phӭc tҥp cӫa giҧi thuұt.
I.4 - Cách tính ÿӝ phӭc tҥp.
I.5 - Phân tích các chѭѫng trình ÿӋ quy.
5. Vҩn ÿӅ nghiên cӭu cӫa trang kӃ tiӃp
Trong chѭѫng này chúng ta sӁ nghiên cӭu các vҩn ÿӅ sau:
· Sӵ cҫn thiӃt phҧi phân tích các giҧi thuұt.
· Thӡi gian thӵc hiӋn cӫa chѭѫng trình.
· Tӹ suҩt tăng và ÿӝ phӭc tҥp cӫa giҧi thuұt.
· Tính thӡi gian thӵc hiӋn cӫa chѭѫng trình.
· Phân tích các chѭѫng trình ÿӋ quy.
I.1- SӴ CҪN THIӂT PHҦI PHÂN TÍCH GIҦI THUҰT
Trong khi giҧi mӝt bài toán chúng ta có thӇ có mӝt sӕ giҧi thuұt khác nhau, vҩn ÿӅ là cҫn phҧi
ÿánh giá các giҧi thuұt ÿó ÿӇ lӵ...
83 trang |
Chia sẻ: hunglv | Lượt xem: 1567 | Lượt tải: 0
Bạn đang xem trước 20 trang mẫu tài liệu Bài giảng Kỹ thuật phân tích giải thuật, để tải tài liệu gốc về máy bạn click vào nút DOWNLOAD ở trên
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................ Trang 1
1. Mөc tiêu
2. KiӃn thӭc cѫ bҧn cҫn có ÿӇ hӑc chѭѫng này
3. Tài liӋu tham khҧo có liên quan ÿӃn chѭѫng
4. Nӝi dung:
I.1 - Sӵ cҫn thiӃt phҧi phân tích giҧi thuұt.
I.2 - Thӡi gian thӵc hiӋn cӫa giҧi thuұt.
I.3 - Tӹ suҩt tăng và ÿӝ phӭc tҥp cӫa giҧi thuұt.
I.4 - Cách tính ÿӝ phӭc tҥp.
I.5 - Phân tích các chѭѫng trình ÿӋ quy.
5. Vҩn ÿӅ nghiên cӭu cӫa trang kӃ tiӃp
Trong chѭѫng này chúng ta sӁ nghiên cӭu các vҩn ÿӅ sau:
· Sӵ cҫn thiӃt phҧi phân tích các giҧi thuұt.
· Thӡi gian thӵc hiӋn cӫa chѭѫng trình.
· Tӹ suҩt tăng và ÿӝ phӭc tҥp cӫa giҧi thuұt.
· Tính thӡi gian thӵc hiӋn cӫa chѭѫng trình.
· Phân tích các chѭѫng trình ÿӋ quy.
I.1- SӴ CҪN THIӂT PHҦI PHÂN TÍCH GIҦI THUҰT
Trong khi giҧi mӝt bài toán chúng ta có thӇ có mӝt sӕ giҧi thuұt khác nhau, vҩn ÿӅ là cҫn phҧi
ÿánh giá các giҧi thuұt ÿó ÿӇ lӵa chӑn mӝt giҧi thuұt tӕt (nhҩt). Thông thѭӡng thì ta sӁ căn cӭ vào các
tiêu chuҭn sau:
1.- Giҧi thuұt ÿúng ÿҳn.
2.- Giҧi thuұt ÿѫn giҧn.
3.- Giҧi thuұt thӵc hiӋn nhanh.
Vӟi yêu cҫu (1), ÿӇ kiӇm tra tính ÿúng ÿҳn cӫa giҧi thuұt chúng ta có thӇ cài ÿһt giҧi thuұt ÿó
và cho thӵc hiӋn trên máy vӟi mӝt sӕ bӝ dӳ liӋu mүu rӗi lҩy kӃt quҧ thu ÿѭӧc so sánh vӟi kӃt quҧÿã
biӃt. Thӵc ra thì cách làm này không chҳc chҳn bӣi vì có thӇ giҧi thuұt ÿúng vӟi tҩt cҧ các bӝ dӳ liӋu
chúng ta ÿã thӱ nhѭng lҥi sai vӟi mӝt bӝ dӳ liӋu nào ÿó. Vҧ lҥi cách làm này chӍ phát hiӋn ra giҧi thuұt
sai chӭ chѭa chӭng minh ÿѭӧc là nó ÿúng. Tính ÿúng ÿҳn cӫa giҧi thuұt cҫn phҧi ÿѭӧc chӭng minh
Eҵng toán hӑc. Tҩt nhiên ÿLӅu này không ÿѫn giҧn và do vұy chúng ta sӁ không ÿӅ cұp ÿӃn ӣÿây.
Khi chúng ta viӃt mӝt chѭѫng trình ÿӇ sӱ dөng mӝt vài lҫn thì yêu cҫu (2) là quan trӑng nhҩt.
Chúng ta cҫn mӝt giҧi thuұt dӉ viӃt chѭѫng trình ÿӇ nhanh chóng có ÿѭӧc kӃt qӫa , thӡi gian thӵc hiӋn
chѭѫng trình không ÿѭӧc ÿӅ cao vì dù sao thì chѭѫng trình ÿó cNJng chӍ sӱ dөng mӝt vài lҫn mà thôi.
Tuy nhiên khi mӝt chѭѫng trình ÿѭӧc sӱ dөng nhiӅu lҫn thì thì yêu cҫu tiӃït kiӋm thӡi gianUpload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................ Trang 2
thӵc hiӋn chѭѫng trình lҥi rҩt quan trӑng ÿһc biӋt ÿӕi vӟi nhӳng chѭѫng trình mà khi thӵc hiӋn cҫn dӳ
liӋu nhұp lӟn do ÿó yêu cҫu (3) sӁÿѭӧc xem xét mӝt cách kӻ càng. Ta gӑi nó là hiӋu quҧ thӡi gian thӵc
hiӋn cӫa giҧi thuұt.
I.2- THӠI GIAN THӴC HIӊN CӪA GIҦI THUҰT
I.2.1- Thӡi gian thӵc hiӋn chѭѫng trình.
I.2.2- Ĉѫn vӏÿo thӡi gian thӵc hiӋn.
I.2.3- Thӡi gian thӵc hiӋn trong trѭӡng hӧp xҩu nhҩt.
Mӝt phѭѫng pháp ÿӇ xác ÿӏnh hiӋu quҧ thӡi gian thӵc hiӋn cӫa mӝt giҧi thuұt là lұp trình nó và ÿo
Oѭӡng thӡi gian thӵc hiӋn cӫa hoҥt ÿӝng trên mӝt máy tính xác ÿӏnh ÿӕi vӟi tұp hӧp ÿѭӧc chӑn lӑc các
Gӳ liӋu vào.
Thӡi gian thӵc hiӋn không chӍ phө thuӝc vào giҧi thuұt mà còn phө thuӝc váo tұp các chӍ thӏ
Fӫa máy tính, chҩt lѭӧng cӫa máy tính và kӻ xҧo cӫa ngѭӡi lұp trình. Sӵ thi hành cNJng có thӇÿLӅu
chӍnh ÿӇ thӵc hiӋn tӕt trên tұp ÿһc biӋt các dӳ liӋu vào ÿѭӧc chӑn. ĈӇ vѭӧt qua các trӣ ngҥi này, các
nhà khoa hӑc máy tính ÿã chҩp nhұn tính phӭc tҥp cӫa thӟi gian ÿѭӧc tiӃp cұn nhѭ mӝt sӵÿo lѭӡng cѫ
Eҧn sӵ thӵc thi cӫa giҧi thuұt. Thuұt ngӳ tính hiӋu quҧ sӁÿӅ cұp ÿӃn sӵÿo lѭӡng này và ÿһc biӋt ÿӕi
Yӟi sӵ phӭc tҥp thӡi gian trong trѭӡng hӧp xҩu nhҩt.
I.2.1- Thӡi gian thӵc hiӋn chѭѫng trình.
Thӡi gian thӵc hiӋn mӝt chѭѫng trình là mӝt hàm cӫa kích thѭӟc dӳ liӋu vào, ký hiӋu T(n) trong ÿó n
là kích thѭӟc (ÿӝ lӟn) cӫa dӳ liӋu vào.
Ví dө 1-1: Chѭѫng trình tính tәng cӫa n sӕ có thӡi gian thӵc hiӋn là T(n) = cn trong ÿó c là
Pӝt hҵng sӕ.
Thӡi gian thӵc hiӋn chѭѫng trình là mӝt hàm không âm, tӭc là T(n) ³0 "n³0.
I.2.2- Ĉѫn vӏÿo thӡi gian thӵc hiӋn.
Ĉѫn vӏ cӫa T(n) không phҧi là ÿѫn vӏÿo thӡi gian bình thѭӡng nhѭ giӡ, phút giây... mà thѭӡng
ÿѭӧc xác ÿӏnh bӣi sӕ các lӋnh ÿѭӧc thӵc hiӋn trong mӝt máy tính lý tѭӣng.
Ví dө 1-2: Khi ta nói thӡi gian thӵc hiӋn cӫa mӝt chѭѫng trình là T(n) = cn thì có nghƭa là
chѭѫng trình ҩy cҫn cn chӍ thӏ thӵc thi.
I.2.3- Thӡi gian thӵc hiӋn trong trѭӡng hӧp xҩu nhҩt.
Nói chung thì thӡi gian thӵc hiӋn chѭѫng trình không chӍ phө thuӝc vào kích thѭӟc mà còn
phө thuӝc vào tính chҩt cӫa dӳ liӋu vào. Nghƭa là dӳ liӋu vào có cùng kích thѭӟc nhѭng thӡi gian thӵc
hiӋn chѭѫng trình có thӇ khác nhau. Chҷng hҥn chѭѫng trình sҳp xӃp dãy sӕ nguyên tăng dҫn, khi ta
cho vào dãy có thӭ tӵ thì thӡi gian thӵc hiӋn khác vӟi khi ta cho vào dãy chѭa có thӭ tӵ, hoһc khi ta
cho vào mӝt dãy ÿã có thӭ tӵ tăng thì thӡi gian thӵc hiӋn cNJng khác so vӟi khi ta cho vào mӝt dãy ÿã
có thӭ tӵ giҧm.
Vì vұy thѭӡng ta coi T(n) là thӡi gian thӵc hiӋn chѭѫng trình trong trѭӡng hӧp xҩu nhҩt trên
Gӳ liӋu vào có kích thѭóc n, tӭc là: T(n) là thӡi gian lӟn nhҩt ÿӇ thӵc hiӋn chѭѫng trình ÿӕi vӟi mӑi dӳ
liӋu vào có cùng kích thѭӟc n.
I.3- TӸ SUҨT TĂNG VÀ ĈӜ PHӬC TҤP CӪA GIҦI THUҰT
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................ Trang 3
I.3.1- Tӹ suҩt tăng
I.3.2- Khái niӋm ÿӝ phӭc tҥp cӫa giҧi thuұt
I.3.1- Tӹ suҩt tăng
Ta nói rҵng hàm không âm T(n) có Wӹ suҩt tăng (growth rate) f(n) nӃu tӗn tҥi các hҵng sӕ c
và n0 sao cho T(n) f(n) vӟi mӑi n n0.
Ta có thӇ chӭng minh ÿѭӧc rҵng “Cho mӝt hàm không âm T(n) bҩt kǤ, ta luôn tìm ÿѭӧc tӹ
suҩt tăng f(n) cӫa nó”.
Ví dө 1-3: Giҧ sӱ T(0) = 1, T(1) = 4 và tәng quát T(n) = (n+1)2. Ĉһt n0 = 1 và c = 4 thì vӟi mӑi
n 1 chúng ta dӉ dàng chӭng minh rҵng T(n) = (n+1)2 4n2 vӟi mӑi n 1, tӭc là tӹ suҩt tăng cӫa T(n)
là n2.
Ví dө 1-4: Tӹ suҩt tăng cӫa hàm T(n) = 3n3 + 2n2 là n3. Thӵc vұy, cho n0 = 0 và c = 5 ta dӉ
dàng chӭng minh rҵng vӟi mӑi n 0 thì 3n3 + 2n2 5n3
I.3.2- Khái niӋm ÿӝ phӭc tҥp cӫa giҧi thuұt
Giҧ sӱ ta có hai giҧi thuұt P1 và P2 vӟi thӡi gian thӵc hiӋn tѭѫng ӭng là T1(n) = 100n2 (vӟi tӹ
suҩt tăng là n2) và T2(n) = 5n3 (vӟi tӹ suҩt tăng là n3). Giҧi thuұt nào sӁ thӵc hiӋn nhanh hѫn? Câu trҧ
Oӡi phө thuӝc vào kích thѭӟc dӳ liӋu vào. Vӟi n < 20 thì P2 sӁ nhanh hѫn P1 (T2<T1), do hӋ sӕ cӫa 5n3
nhӓ hѫn hӋ sӕ cӫa 100n2 (5 20 thì ngѭѫc lҥi do sӕ mNJ cӫa 100n2 nhӓ hѫn sӕ mNJ
Fӫa 5n3 (220 vì khi n<20 thì thӡi gian thӵc
hiӋn cӫa cҧ P1 và P2 ÿӅu không lӟn và sӵ khác biӋt giӳa T1 và T2 là không ÿáng kӇ..
Nhѭ vұy mӝt cách hӧp lý là ta xét tӹ suҩt tăng cӫa hàm thӡi gian thӵc hiӋn chѭѫng trình thay
vì xét chính bҧn thân thӡi gian thӵc hiӋn.
Cho mӝt hàm T(n), T(n) gӑi là có ÿӝ phӭc tҥp f(n) nӃu tӗn tҥi các hҵng c, N0 sao cho T(n)
cf(n) vӟi mӑi n N0 (tӭc là T(n) có tӹ suҩt tăng là f(n)) và kí hiӋu T(n) là O(f(n)) (ÿӑc là “ô cӫa f(n)”)
Ví dө 1-5: T(n)= (n+1)2 có tӹ suҩt tăng là n2 nên T(n)= (n+1)2 là O(n2)
Chú ý: O(c.f(n))=O(f(n)) vӟi c là hҵng sӕ. Ĉһc biӋt O(c)=O(1)
Nói cách khác ÿӝ phӭc tҥp tính toán cӫa giҧi thuұt là mӝt hàm chһn trên cӫa hàm thӡi gian. Vì
Kҵng nhân tӱ c trong hàm chһn trên không có ý nghƭa nên ta có thӇ bӓ qua vì vұy hàm thӇ hiӋn ÿӝ phӭc
Wҥp có các dҥng thѭӡng gһp sau: log2n, n, nlog2n, n2, n3, 22, n!, nn. Ba hàm cuӕi cùng ta gӑi là dҥng
hàm mNJ, các hàm khác gӑi là hàm ÿa thӭc. Mӝt giҧi thuұt mà thӡi gian thӵc hiӋn có ÿӝ phӭc tҥp là mӝt
hàm ÿa thӭc thì chҩp nhұn ÿѭӧc tӭc là có thӇ cài ÿһt ÿӇ thӵc hiӋn, còn các giҧi thuұt có ÿӝ phӭc tҥp
hàm mNJ thì phҧi tìm cách cҧi tiӃn giҧi thuұt.
Khi nói ÿӃn ÿӝ phӭc tҥp cӫa giҧi thuұt là ta muӕn nói ÿӃn hiӋu quҧ cӫa thӡi gian thӵc hiӋn cӫa
chѭѫng trình nên ta có thӇ xem viӋc xác ÿӏnh thӡi gian thӵc hiên cӫa chѭѫng trình chính là xác ÿӏnh ÿӝ
phӭc tҥp cӫa giҧi thuұt.
I.4- CÁCH TÍNH ĈӜ PHӬC TҤP
I.4.1- Qui tҳc cӝng
I.4.2- Qui tҳc nhân Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................ Trang 4
I.4.3- Qui tҳc tәng quát ÿӇ phân tích mӝt chѭѫng trình
I.4.4- Ĉӝ phӭc tҥp cӫa chѭѫng trình có gӑi chѭѫng trình con không ÿӋ qui
Cách tính ÿӝ phӭc tҥp cӫa mӝt giҧi thuұt bҩt kǤ là mӝt vҩn ÿӅ không ÿѫn giҧn. Tuy nhiên ta có
thӇ tuân theo mӝt sӕ nguyên tҳc sau:
I.4.1- Qui tҳc cӝng:
NӃu T1(n) và T2(n) là thӡi gian thӵc hiӋn cӫa hai ÿRҥn chѭѫng trình P1 và P2; và
T1(n)=O(f(n)), T2(n)=O(g(n) thì thӡi gian thӵc hiӋn cӫa ÿRҥn hai chѭѫng trình ÿó Qӕi tiӃp nhau là
T(n)=O(max(f(n),g(n)))
Ví dө 1-6: LӋnh gán x:=15 tӕn mӝt hҵng thӡi gian hay O(1)
LӋnh ÿӑc dӳ liӋu READ(x) tӕn mӝt hҵng thӡi gian hay O(1)
Vұy thӡi gian thӵc hiӋn cҧ hai lӋnh trên nӕi tiӃp nhau là O(max(1,1))=O(1)
I.4.2- Qui tҳc nhân:
NӃu T1(n) và T2(n) là thӡi gian thӵc hiӋn cӫa hai ÿRҥn chѭѫng trình P1và P2 và T1(n) =
O(f(n)), T2(n) = O(g(n) thì thӡi gian thӵc hiӋn cӫa ÿRҥn hai ÿRҥn chѭѫng trình ÿó Oӗng nhau là T(n) =
O(f(n).g(n))
I.4.3- Qui tҳc tәng quát ÿӇ phân tích mӝt chѭѫng trình:
- Thӡi gian thӵc hiӋn cӫa mӛi lӋnh gán, READ, WRITE là O(1)
- Thӡi gian thӵc hiӋn cӫa mӝt chuӛi tuҫn tӵ các lӋnh ÿѭӧc xác ÿӏnh bҵng qui tҳc cӝng. Nhѭ
Yұy thӡi gian này là thӡi gian thi hành mӝt lӋnh nào ÿó lâu nhҩt trong chuӛi lӋnh.
- Thӡi gian thӵc hiӋn cҩu trúc IF là thӡi gian lӟn nhҩt thӵc hiӋn lӋnh sau THEN hoһc sau ELSE
và thӡi gian kiӇm tra ÿLӅu kiӋn. Thѭӡng thӡi gian kiӇm tra ÿLӅu kiӋn là O(1).
- Thӡi gian thӵc hiӋn vòng lһp là tәng (trên tҩt cҧ các lҫn lһp) thӡi gian thӵc hiӋn thân vòng
Oһp. NӃu thӡi gian thӵc hiӋn than vòng lһp không ÿәi thì thӡi gian thӵc hiӋn vòng lһp là tích cӫa sӕ lҫn
Oһp vӟi thӡi gian thӵc hiӋn thân vòng lһp.
Ví dө 1-7: Tính thӡi gian thӵc hiӋn cӫa ÿRҥn chѭѫng trình
procedure Bubble (var a: array[1..n] of integer);
var i,j,temp: integer;
begin
{1} for i:=1 to n-1 do
{2} for j:=n downto i+1 do
{3} if a[j-1]>a[j] then begin
{ ÿәi chә a[i], a[j] }
{4} temp:=a[j-1];
{5} a[j-1]:=a[j];
{6} a[j]:=temp; end;
end;
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................ Trang 5
Cҧ ba lӋnh ÿәi chӛ {4} {5} {6} tӕn O(1) thӡi gian, do ÿó lӋnh {3} tӕn O(1).
Vòng lһp {2} thӵc hiӋn (n-i) lҫn, mӛi lҫn O(1) do ÿó vòng lһp {2} tӕn O((n-i).1)=O(n-i).
Vòng lһp {1} lһp (n-1) lҫn vұy ÿӝ phӭc tҥp cӫa giҧi thuұt là:
I.4.4- Ĉӝ phӭc tҥp cӫa chѭѫng trình có gӑi chѭѫng trình con không ÿӋ qui
NӃu chúng ta có mӝt chѭѫng trình vӟi các chѭѫng trình con không ÿӋ quy, ÿӇ tính thӡi gian
thӵc hiӋn cӫa chѭѫng trình, trѭӟc hӃt chúng ta tính thӡi gian thӵc hiӋn cӫa các chѭѫng trình con không
Jӑi các chѭѫng trình con khác. Sau ÿó chúng ta tính thӡi gian thӵc hiӋn cӫa các chѭѫng trình con chӍ
Jӑi các chѭѫng trình con mà thӡi gian thӵc hiӋn cӫa chúng ÿã ÿѭӧc tính. Chúng ta tiӃp tөc quá trình
ÿánh giá thӡi gian thӵc hiӋn cӫa mӛi chѭѫng trình con sau khi thӡi gian thӵc hiӋn cӫa tҩt cҧ các
chѭѫng trình con mà nó gӑi ÿã ÿѭӧc ÿánh giá. Cuӕi cùng ta tính thӡi gian cho chѭѫng trình chính.
Giҧ sӱ ta cô mӝt hӋ thӕng các chѭѫng trình gӑi theo sѫÿӗ sau:
Chѭѫng trình A gӑi hai chѭѫng trình con là B và C, chѭѫng trình B gӑi hai chѭѫng trình con là
B1 và B2, chѭѫng trình B1 gӑi hai chѭѫng trình con là B11 và B12.
ĈӇ tính thӡi gian thӵc hiӋn cӫa A, ta tính theo các bѭӟc sau:
- Tính thӡi gian thӵc hiӋn cӫa C, B2, B11 và B12.
- Tính thӡi gian thӵc hiӋn cӫa B1.
- Tính thӡi gian thӵc hiӋn cӫa B.
- Tính thӡi gian thӵc hiӋn cӫa A.
Ví dө 1-8: Ta có thӇ viӃt lҥi chѭѫng trình sҳp xӃp bubble nhѭ sau:
procedure Swap (var x, y: integer);
var temp: integer;
begin
temp := x;
x := y;
y := temp;
end;
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................ Trang 6
procedure Bubble (var a: array[1..n] of integer);
var i,j :integer;
begin
{1} for i:=1 to n-1 do
{2} for j:=n downto i+1 do
{3} if a[j-1]>a[j] then Swap(a[j-1], a[j]);
end;
Trong cách viӃt trên, chѭѫng trình Bubble gӑi chѭѫng trình con Swap, do ÿó ÿӇ tính thӡi gian
thӵc hiӋn cӫa Bubble, trѭӟc hӃt ta cҫn tính thӡi gian thӵc hiӋn cӫa Swap. DӉ thҩy thӡi gian thӵc hiӋn
Fӫa Swap là O(1) vì nó chӍ bao gӗm 3 lӋnh gán.
Trong Bubble, lӋnh {3} gӑi Swap nên chӍ tӕn O(1), lӋnh {2} thӵc hiӋn n-i lҫn, mӛi lҫn tӕn
O(1) nên tӕn O(n-i). LӋnh {1} thӵc hiӋn n-1 lҫn nên
I.5- PHÂN TÍCH CÁC CHѬѪNG TRÌNH Ĉӊ QUY
I.5.1- Thành lұp phѭѫng trình ÿӋ quy
I.5.2- Giҧi phѭѫng trình ÿӋ quy
Vӟi các chѭѫng trình có gӑi các chѭѫng trình con ÿӋ quy, ta không thӇ áp dөng cách tính nhѭ
Yӯa trình bày trong mөc I.4.4 bӣi vì mӝt chѭѫng trình ÿӋ quy sӁ gӑi chính bҧn thân nó.
Vӟi các chѭѫng trình ÿӋ quy, trѭӟc hӃt ta cҫn thành lұp các phѭѫng trình ÿӋ quy, sau ÿó giҧi
phѭѫng trình ÿӋ quy, nghiӋm cӫa phѭѫng trình ÿӋ quy sӁ là thӡi gian thӵc hiӋn cӫa chѭѫng trình ÿӋ
quy.
I.5.1- Thành lұp phѭѫng trình ÿӋ quy
Phѭѫng trình ÿӋ quy là mӝt phѭѫng trình biӇu diӉn mӕi liên hӋ giӳa T(n) và T(k), trong ÿó
T(n) là thӡi gian thӵc hiӋn chѭѫng trình vӟi kích thѭӟc dӳ liӋu nhұp là n, T(k) thӡi gian thӵc hiӋn
chѭѫng trình vӟi kích thѭӟc dӳ liӋu nhұp là k, vӟi k < n. ĈӇ thành lұp ÿѭӧc phѭѫng trình ÿӋ quy, ta
phҧi căn cӭ vào chѭѫng trình ÿӋ quy.
Ví dө 1-9: Xét hàm tính giai thӯa viӃt bҵng giҧi thuұt ÿӋ quy nhѭ sau:
function Giai_thua(n:integer): integer;
begin
if n=0 then Giai_thua :=1
else Giai_thua := n* Giai_thua(n-1);
end;
*ӑi T(n) là thӡi gian thӵc hiӋn viӋc tính n giai thӯa, thì T(n-1) là thӡi gian thӵc hiӋn viӋc tính
n-1 giai thӯa. Trong trѭӡng hӧp n=0 thì chѭѫng trình chӍ thӵc hiӋn mӝt lӋnh gán Giai_thua:=1, nên tӕn
O(1), do ÿó ta có T(0) = C1. Trong trѭӡng hӧp n>0 chѭѫng trình phҧi gӑi ÿӋ quy Giai_thua(n-1), viӋc
Jӑi ÿӋ quy này tӕn T(n-1), sau khi có kӃt quҧ cӫa viӋc gӑi ÿӋ quy, chѭѫng trình phҧi nhân kӃt quҧÿó
Yӟi n và gán cho Giai_thua. Thӡi gian ÿӇ thӵc hiӋn phép nhân và phép gán là mӝt hҵng C2. Vұy ta có
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................ Trang 7
Ĉây là phѭѫng trình ÿӋ quy ÿӇ tính thӡi gian thӵc hiӋn cӫa chѭѫng trình ÿӋ quy Giai_thua.
Ví dө 1-10: Chúng ta xét thӫ tөc MergeSort mӝt cách phác thҧo nhѭ sau:
function MergeSort (L:List ; n:integer) : List;
var
L1,L2 : List;
begin
if n = 1 then return(L)
else
begin
Chia L thành 2 nӱa L1 và L2 , mӛi mӝt nӱa có ÿӝ dài n/2;
return(Merge(MergeSort (L1 , n/2), MergeSort(L2, n/2)));
end;
end;
Chҷng hҥn ÿӇ sҳp xӃp danh sách L gӗm 8 phҫn tӱ 7, 4, 8, 9, 3, 1, 6, 2 ta có mô hình minh hӑa
Fӫa MergeSort nhѭ sau:
Hàm MergeSort nhұn mӝt danh sách có ÿӝ dài n và trҧ vӅ mӝt danh sách ÿã ÿѭӧc sҳp xӃp. Thӫ
Wөc Merge nhұn hai danh sách ÿã ÿѭӧc sҳp L1 và L2 mӛi danh sách có ÿӝ dài n/2, trӝn chúng lҥi vӟi
nhau ÿӇÿѭӧc mӝt danh sách gӗm n phҫn tӱ có thӭ tӵ. Giҧi thuұt chi tiӃt cӫa Merge ta sӁ bàn sau,
chúng ta chӍÿӇ ý rҵng thӡi gian ÿӇ Merge các danh sách có ÿӝ dài n/2 là O(n).
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................ Trang 8
Gӑi T(n) là thӡi gian thӵc hiӋn MergeSort mӝt danh sách n phҫn tӱ thì T(n/2) là thӡi gian thӵc
hiӋn MergeSort mӝt danh sách n/2 phҫn tӱ , ta có thӇ viӃt phѭѫng trình ÿӋ quy nhѭ sau:
Trong ÿó c1 là thӡi gian phҧi tӕn khi L có ÿӝ dài 1. Trong trѭӡng hӧp n > 1, thӡi gian cӫa
MergeSort ÿѭӧc chia làm hai phҫn. Phҫn gӑi ÿӋ quy MergeSort mӝt danh sách có ÿӝ dài n/2 là T(n/2)
do ÿó ta có 2T(n/2). Phҫn thӭ hai bao gӗm phép thӱ n >1, chia danh sách L thành hai nӱa bҵng nhau và
Merge. Ba thao tác này lҩy thӡi gian không ÿәi ÿӕi vӟi phép thӱ hoһc tӹ lӋ vӟi n ÿӕi vӟi ngҳt và
Merge. Nhѭ vұy hҵng c2ÿѭӧc chӑn và c2n là thӡi gian tәng ÿӇ làm các viӋc ÿó ngoҥi trӯ gӑi ÿӋ quy.
I.5.2- Giҧi phѭѫng trình ÿӋ quy
Có ba phѭѫng pháp giҧi phѭѫng trình ÿӋ quy:
1.- Phѭѫng pháp truy hӗi
2.- Phѭѫng pháp ÿoán nghiӋm.
3.- Lӡi giҧi tәng quát cӫa mӝt lӟp các phѭѫng trình ÿӋ quy.
Phѭѫng pháp truy hӗi
Dùng ÿӋ quy ÿӇ thay thӃ bҩt kǤ T(m) vӟi m < n vào phía phҧi cӫa phѭѫng trình cho ÿӃn khi tҩt
Fҧ T(m) vӟi m > 1 ÿѭӧc thay thӃ bӣi biӇu thӭc cӫa các T(1). Vì T(1) luôn là hҵng nên chúng ta có công
thӭc cӫa T(n) chӭa các sӕ hҥng chӍ liên quan ÿӃn n và các hҵng sӕ.
Giҧi phѭѫng trình.
Ví dө 1-10: Giҧi phѭѫng trình:
Ta có:
Giҧ sӱ n = 2k, quá trình suy rӝng sӁ kӃt thúc khi i =k, khi ÿó ta có:
T(n) = 2kT(1) + kC2n
Vì 2k = n nên k = logn và vӟi T(1) =C1 nên ta có
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................ Trang 9
T(n) = C1n + C2nlogn
Hay T(n) là O(nlogn).
Ĉoán nghiӋm
Ta ÿoán mӝt nghiӋm f(n) và dùng chӭng minh quy nҥp ÿӇ chӭng tӓ rҵng T(n) f(n) vӟi mӑi n.
Thông thѭӡng f(n) là mӝt trong các hàm quen thuӝc nhѭ logn, n, nlogn, n2, n3, 2n, n!, nn.
Ĉôi khi chúng ta chӍÿoán dҥng cӫa f(n) trong ÿó có mӝt vài tham sӕ chѭa xác ÿӏnh (chҷng hҥn
f(n) = an2 vӟi a chѭa xác ÿӏnh) và trong quá trình chӭng minh quy nҥp ta sӁ suy diӉn ra giá trӏ thích
Kӧp cӫa các tham sӕ.
Ví dө 1-11: Giҧi phѭѫng trình ÿӋ quy
Giҧ sӱ chúng ta ÿoán f(n) = anlogn. Vӟi n = 1 ta thҩy rҵng cách ÿoán nhѭ vұy không ÿѭӧc bӣi
vì anlog n có giá trӏ 0 không phө thuӝc vào giá trӏ cӫa a. Vì thӃ ta thӱ tiӃp theo f(n) = anlogn + b.
Vӟi n = 1 ta có, T(1) = C1 và f(1) = b, muӕn T(1) f(1) thì b C1 (*)
Giҧ sӱ rҵng T(k) aklogk + b vӟi mӑi k < n (I.2).Ta sӁ chӭng minh T(n) anlogn + b
Giҧ sӱ n 2, tӯ (I.1) ta có T(n) = 2T(n/2) + C2n
Áp dөng (I.2) vӟi k = n/2 < n ta có:
T(n) = 2T(n/2) + C2n 2[an/2log(n/2) + b] + C2n
T(n) anlogn - an + 2b + C2n
T(n) (anlogn + b) + [b + (C2 - a)n] . NӃu lҩy a C2 + b (**) ta ÿѭӧc
T(n) (anlogn + b) + [b +(C2 - C2 - b )n ]
T(n) (anlogn + b) + (1-n) b
T(n) an logn + b.
NӃu ta lҩy a và b sao cho cҧ (*) và (**) ÿӅu thoҧ mãn thì T(n) an logn + b vӟi mӑi n.
DӉ dàng ta có b = C1 và a= C1 +C2 ta ÿѭӧc T(n) (C1 + C2)nlogn + C1 vӟi mӑi n.Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 10
Hay nói cách khác T(n) là O(nlogn).
/ӡi giҧi tәng quát cho mӝt lӟp các phѭѫng trình ÿӋ quy
ĈӇ giҧi bài toán kích thѭӟc n, ta chia bài toán ÿã cho thành a bài toán con, mӛi bài tóan con có
kích thѭӟc n/b. Giҧi các bài toán con này và tәng hӧp kӃt quҧ lҥi ÿӇÿѭӧc kӃt quҧ cӫa bài toán ÿã cho.
9ӟi các bài toán con chúng ta cNJng làm nhѭ vұy. Kӻ thuұt này sӁ dүn chúng ta ÿӃn mӝt chѭѫng trình
ÿӋ quy.
Giҧ thiӃt rҵng mӛi bài toán con kích thѭӟc 1 lҩy mӝt ÿѫn vӏ thӡi gian và thӡi gian ÿӇ chia bài
toán kích thѭӟc n thành các bài toán con kích thѭӟc n/b và tәng hӧp kӃt quҧ tӯ các bài toán con ÿӇ
ÿѭӧc lӡi giҧi cӫa bài toán ban ÿҫu là d(n). (Chҷng hҥn ÿӕi vӟi thí dө MergeSort, chúng ta có a = b = 2,
và d(n) = C2n/C1. Xem C1 là mӝt ÿѫn vӏ).
Gӑi T(n) là thӡi gian ÿӇ giҧi bài toán kích thѭӟc n thì ta có phѭѫng trình ÿӋ quy:
Ta sӱ dөng phѭѫng pháp truy hӗi ÿӇ giҧi phѭѫng trình này
Giҧ sӱ n = bk ta ÿѭӧc: T(n/bk) = T(1) = 1. Thay vào trên vӟi i = k ta có:
Hàm tiӃn triӇn, nghiӋm thuҫn nhҩt và nghiӋm riêng
Trong phѭѫng trình ÿӋ quy (I.1) hàm thӡi gian d(n) ÿѭӧc gӑi là hàm tiӃn triӇn (driving
function)
Trong công thӭc (I.2), ak = nlogbaÿѭӧc gӑi là nghiӋm thuҫn nhҩt (homogeneous solutions).
NghiӋm thuҫn nhҩt là nghiӋm chính xác khi d(n) = 0 vӟi mӑi n. Nói mӝt cách khác, nghiӋm
thuҫn nhҩt biӇu diӉn thӡi gian ÿӇ giҧi tҩt cҧ các bài toán con.
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 11
Trong công thӭc (I.2), ÿѭӧc gӑi là nghiӋm riêng (particular solutions).
NghiӋm riêng biӇu diӉn thӡi gian phҧi trҧÿӇ tҥo ra các bài toán con và tәng hӧp các kӃt quҧ
Fӫa chúng. Nhìn vào công thӭc ta thҩy nghiӋm riêng phө thuӝc vào hàm tiӃn triӇn, sӕ lѭӧng và kích
thѭӟc các bài toán con.
Khi tìm nghiӋm cӫa phѭѫng trình (I,1), chúng ta phҧi tìm nghiӋm riêng và so sánh vӟi nghiӋm
thuҫn nhҩt. NӃu nghiӋm nào lӟn hѫn, ta lҩy nghiӋm ÿó làm nghiӋm cӫa phѭѫng trình (I,1).
ViӋc xác ÿӏnh nghiӋm riêng không ÿѫn giҧn chút nào, tuy vұy, chúng ta cNJng tìm ÿѭӧc mӝt lӟp
các hàm tiӃn triӇn có thӇ dӉ dàng xác ÿӏnh nghiӋm riêng.
Hàm nhân
Mӝt hàm f(n) ÿѭӧc gӑi là hàm nhân (multiplicative function) nӃu f(m.n) = f(m).f(n) vӟi mӑi
Vӕ nguyên dѭѫng m và n.
Ví dө 1-12: Hàm f(n) = nk là mӝt hàm nhân, vì f(m.n) = (m.n)k = mk.nk = f(m) f(n)
1Ӄu d(n) trong (I.1) là mӝt hàm nhân thì theo tính chҩt cӫa hàm nhân ta có
d(bk-j) = (d(b))k-j và nghiӋm riêng cӫa (I.2) là:
Xét ba trѭӡng hӧp sau:
1.- NӃu a > d(b) thì nghiӋm riêng là O(ak) = O(nlogba). Nhѭ vұy nghiӋm riêng và nghiӋm thuҫn
nhҩt bҵng nhau do ÿó T(n) là O(nlogba).
Ta cNJng thҩy thӡi gian thӵc hiӋn chӍ phө thuӝc vào a, b mà không phө thuӝc vào hàm tiӃn triӇn
d(n). Vì vұy ÿӇ cҧi tiӃn giҧi thuұt ta cҫn giҧm a hoһc tăng b.
2.- NӃu a < d(b) thì nghiӋm riêng là O(d(b)k) = O(nlogbd(b)). Trong trѭӡng hӧp này nghiӋm riêng
Oӟn hѫn nghiӋm thuҫn nhҩt nên T(n) = O(nlogbd(b)).
ĈӇ cҧi tiӃn giҧi thuұt chúng ta cҫn ÿӇ ý ÿӃn cҧ d(n), a và b cùng mӭc ÿӝ nhѭ nhau.
Trѭӡng hӧp ÿһc biӋt quan trӑng khi d(n) = nĮ . Khi ÿó d(b) = bĮ và logb(bĮ) = Į. Vì thӃ nghiӋm
riêng là O(nĮ) và do vұy T(n) là O(nĮ).
3.- NӃu a = d(b) thì công thӭc (I.5) không xác ÿinh nên ta tính trӵc tiӃp nghiӋm riêng:
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 12
Vì a= d(b) nên nghiӋm riêng là nlogbalogbn và nghiӋm này lӟn gҩp logbn lҫn nghiӋm thuҫn nhҩt.
Do ÿó T(n) = O(nlogbalogbn).
Trong trѭӡng hӧp ÿһc biӋt d(n) = nĮ ta ÿѭӧc T(n) = O(nĮlogn).
Chú ý khi giҧi mӝt phѭѫng trình ÿӋ quy cө thӇ, ta phҧi xem phѭѫng trình ÿó có thuӝc dҥng
phѭѫng trình tәng quát hay không. NӃu có thì phҧi xét xem hàm tiӃn triӇn có phҧi là hàm nhân không.
1Ӄu có thì ta xác ÿӏnh a, d(b) và dӵa vào sӵ so sánh giӳa a và d(b) mà vұn dөng mӝt trong ba trѭӡng
Kӧp nói trên.
Ví dө 1-13: Giҧi các phѭѫng trình ÿӋ quy sau vӟi T(1) = 1 và
1/- T(n) = 4T(n/2) + n
2/- T(n) = 4T(n/2) + n2
3/- T(n) = 4T(n/2) + n3
Trong mӛi trѭӡng hӧp, a=4, b=2 và nghiӋm thuҫn nhҩt là n2. Vӟi d(n) = n ta có d(b) = 2 vì a =
4 > d(b) nên nghiӋm riêng cNJng là n2 và T(n) = O(n2) trong phѭѫng trình (1).
Trong phѭѫng trình (3), d(n) = n3, d(b) = 8 và a < d(b). Vì vұy nghiӋm riêng là O(nlogbd(b)) =
O(n3) và T(n) cӫa (3) là O(n3).
Trong phѭѫng trình (2) chúng ta có d(b) = 4 = a nên T(n) = O(n2logn).
Các hàm tiӃn triӇn khác
Ta xét hai trѭӡng hӧp dѭӟi dҥng hai ví dө, trѭӡng hӧp 1 là tәng quát hóa cӫa hàm bҩt kǤ là tích
Fӫa mӝt hàm nhân vӟi mӝt hҵng lӟn hѫn hoһc bҵng 1. Trѭӡng hӧp thӭ hai là hàm tiӃn triӇn không phҧi
là mӝt hàm nhân.
Ví dө 1-14: Giҧi pgѭѫng trình ÿӋ quy sau :
T(1) = 1
T(n) = 3T(n/2) + 2n1.5
Ӣÿây, 2n1.5 không phҧi là hàm nhân nhѭng n1.5 là hàm nhân. Ĉһt U(n) = T(n)/2 vӟi mӑi n thì
U(1) = 1/2
U(n) = 3U(n/2) + n1.5
NghiӋm thuҫn nhҩt khi U(1) = 1 là nlog3 = n1.59; vì U(1) = 1/2 nên nghiӋm thuҫn nhҩt là n1.59/2 là
O(n1.59). Vì a = 3 và b = 2 và b1.5 = 2.82 < a, nghiӋm riêng cNJng là O(n1.59) và do ÿó U(n) = O(n1.59) . Vì
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 13
T(n) = 2U(n) nên T(n) = O(n1.59) hay T(n) = O(nlog3).
Ví dө 1-15: Giҧi phѭѫng trình ÿӋ quy sau :
T(1) = 1
T(n) = 2T(n/2) + nlogn
Vì a = b = 2 nên nghiӋm thuҫn nhҩt là n. Tuy nhiên, d(n) = nlogn không phҧi là hàm nhân ta
phҧi tính nghiӋm riêng bҵng cách xét trӵc tiӃp:
Vì k = logn chúng ta có nghiӋm riêng là O(nlog2n), nghiӋm này lӟn hѫn nghiӋm thuҫn nhҩt và
T(n) = O(nlog2n).
Bài 1: Tính thӡi gian thӵc hiӋn cӫa các ÿRҥn chѭѫng trình sau:
a) Tính tәng cӫa các sӕ
Sum := 0;
for i:=1 to n do begin
readln(x);
Sum := Sum + x;
end;
b) Tính tích hai ma trұn vuông cҩp n C = A*B:
for i := 1 to n do
for j := 1 to n do begin
c[i,j] := 0;
for k := 1 to n do c[i,j] := c[i,j] + a[i,k] * b[k,j];
end;
Bài 2: Giҧi các phѭѫng trình ÿӋ quy sau vӟi T(1) = 1 và
a) T(n) = 3T(n/2) + n
b) T(n) = 3T(n/2) + n2
c) T(n) = 8T(n/2) + n3
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 14
Bài 3: Giҧi các phѭѫng trình ÿӋ quy sau vӟi T(1) = 1 và
a) T(n) = 4T(n/3) + n
b) T(n) = 4T(n/3) + n2
c) T(n) = 9T(n/3) + n2
Bài 4: Giҧi các phѭѫng trình ÿӋ quy sau vӟi T(1) = 1 và
a) T(n) = T(n/2) + 1
b) T(n) = 2T(n/2) + logn
c) T(n) = 2T(n/2) + n
d) T(n) = 2T(n/2) + n2
Bài 5: Giҧi các phѭѫng trình ÿӋ quy sau bҵng phѭѫng pháp ÿoán nghiӋm:
a) T(1) = 2 và T(n) = 2T(n-1) + 1 vӟi " n 2
b) T(1) = 1 và T(n) = 2T(n-1) + n vӟi " n 2
Bài 6: Cho mӝt mҧng n sӕ nguyên ÿѭӧc sҳp thӭ tӵ tăng. ViӃt hàm tìm mӝt sӕ nguyên trong
Pҧng ÿó, nӃu tìm thҩy thì trҧ vӅ TRUE, ngѭӧc lҥi trҧ vӅ FALSE.
6ӱ dөng hai phѭѫng pháp tìm kiӃm tuҫn tӵ và tìm kiӃm nhӏ phân. Vӟi mӛi phѭѫng pháp hãy viӃt mӝt
hàm tìm và tính thӡi gian thӵc hiӋn cӫa hàm ÿó.
Bài 7: Tính thӡi gian thӵc hiӋn cӫa giҧi thuұt ÿӋ quy giҧi bài toán Tháp Hà nӝi vӟi n tҫng?
Bài 8: Xét ÿӏnh nghƭa sӕ tә hӧp chұp k cӫa n nhѭ sau:
a) ViӃt mӝt hàm ÿӋ quy ÿӇ tính sӕ tә hӧp chұp k cӫa n.
Tính thӡi gian thӵc hiӋn cӫa giҧi thuұt nói trên.
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 15
1. Mөc tiêu
2. KiӃn thӭc cѫ bҧn cҫn có ÿӇ hӑc chѭѫng này
3. Tài liӋu tham khҧo có liên quan ÿӃn chѭѫng
4. Nӝi dung:
II.1 - Bài toán sҳp xӃp.
II.2 - Các phѭѫng pháp sҳp xӃp ÿѫn giҧn
II.3 - Quicksort.
II.4 - Heapsort.
II.5 - Binsort.
5. Vҩn ÿӅ nghiên cӭu cӫa trang kӃ tiӃp
Trong chѭѫng này chúng ta sӁ nghiên cӭu các vҩn ÿӅ sau:
· Bài toán sҳp xӃp.
· Mӝt sӕ giҧi thuұt sҳp xӃp ÿѫn giҧn.
· QuickSort
· HeapSort
· BinSort
II.1- BÀI TOÁN SҲP XӂP
II.1.1 Tҫm quan trӑng cӫa bài toán sҳp xӃp
II.1.2 Sҳp xӃp trong và sҳp xӃp ngoài
II.1.3 Tә chӭc dӳ liӋu và ngôn ngӳ cài ÿһt
II.1.1 Tҫm quan trӑng cӫa bài toán sҳp xӃp
Sҳp xӃp mӝt danh sách các ÿӕi tѭӧng theo mӝt thӭ tӵ nào là mӝt bài toán thѭӡng ÿѭӧc vұn
Gөng trong các ӭng dөng tin hӑc. Ví dө ta cҫn sҳp xӃp danh sách thí sinh theo tên vӟi thӭ tӵ Alphabet,
hoһc sҳp xӃp danh sách sinh viên theo ÿLӇm trung bình vӟi thӭ tӵ tӯ cao ÿӃn thҩp. Mӝt ví dө khác là
khi cҫn tìm kiӃm mӝt ÿӕi tѭӧng trong mӝt danh sách các ÿӕi tѭӧng bҵng giҧi thuұt tìm kiӃm nhӏ phân
thì danh sách các ÿӕi tѭӧng này phҧi ÿѭӧc sҳp xӃp trѭӟc ÿó.
Tóm lҥi sҳp xӃp là mӝt yêu cҫu không thӇ thiӃu trong khi thiӃt kӃ các phҫn mӅm.
II.1.2 Sҳp xӃp trong và sҳp xӃp ngoài
Sҳp xӃp trong là sӵ sҳp xӃp dӳ liӋu ÿѭӧc tә chӭc trong bӝ nhӟ trong cuҧ máy tính, ӣÿó ta có
thӇ sӱ dөng khҧ năng truy nhұp ngүu nhiên cӫa bӝ nhӟ và do vұy sӵ thӵc hiӋn rҩt nhanh.
Sҳp xӃp ngoài là sӵ sҳp xӃp ÿѭӧc sӱ dөng khi sӕ lѭӧng ÿӕi tѭӧng ÿѭӧc sҳp xӃp lӟn không thӇ
Oѭu trӳ trong bӝ nhӟ trong mà phҧi lѭu trӳî trên bӝ nhӟ ngoài. Cө thӇ là ta sӁ sҳp xӃp dӳ liӋu ÿѭӧc lѭu
trӳ trong các tұp tin. Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 16
Chѭѫng này tұp trung giҧi quyӃt vҩn ÿӅ sҳp xӃp trong còn sҳp xӃp ngoài sӁÿѭӧc nghiên cӭu
trong chѭѫng IV.
II.1.3 Tә chӭc dӳ liӋu và ngôn ngӳ cài ÿһt
Các ÿӕi tѭӧng cҫn ÿѭӧc sҳp xӃp là các mҭu tin gӗm mӝt hoһc nhiӅu trѭӡng. Mӝt trong các
trѭӡng ÿѭӧc gӑi là khóa (key), kiӇu cӫa nó là mӝt kiӇu có quan hӋ thӭ tӵ (nhѭ các kiӇu sӕ nguyên, sӕ
thӵc, chuӛi ký tӵ...).
Danh sách các ÿӕi tѭӧng cҫn sҳp xӃp sӁ là mӝt mҧng cӫa các mҭu tin vӯa nói ӣ trên. Mөc ÿích
Fӫa viӋc sҳp xӃp là tә chӭc lҥi các mҭu tin sao cho các khóa cӫa chúng ÿѭӧc sҳp thӭ tӵ tѭѫng ӭng vӟi
quy luұt sҳp xӃp.
ĈӇ trình bày các ví dө minh hӑa chúng ta sӁ dùng PASCAL làm ngôn ngӳ thӇ hiӋn và sӱ dөng
khai báo sau:
const N = 100;
type
KeyType = integer;
OtherType = real;
RecordType = Record
Key : KeyType;
OtherFields : OtherType;
end;
var
a : array[1..N] of RecordType;
procedure Swap(var x,y:RecordType);
var
temp : RecordType;
begin
temp := x;
x := y;
y := temp;
end;
&ҫn thҩy rҵng thӫ tөc Swap lҩy O(1) thӡi gian vì chӍ thӵc hiӋn 3 lӋnh gán nӕi tiӃp nhau.
II.2- CÁC PHѬѪNG PHÁP SҲP XӂP ĈѪN GIҦN
II.2.1- Sҳp xӃp chӑn
II.2.2- Sҳp xӃp xen
II.2.3- Sҳp xӃp nәi bӑt
Các giҧi thuұt ÿѫn giҧn thѭӡng lҩy O(n2) thӡi gian ÿӇ sҳp xӃp n ÿӕi tѭӧng và các giҧi thuұt này
thѭӡng chӍ dùng ÿӇ sҳp các danh sách có ít ÿӕi tѭӧng.
Vӟi mӛi giҧi thuұt chúng ta sӁ nghiên cӭu các phҫn: giҧi thuұt, ví dө, chѭѫng trình và phân tích
ÿánh giá.
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 17
II.2.1- Sҳp xӃp chӑn (Selection Sort)
Giҧi thuұt
Ĉây là phѭѫng pháp sҳp xӃp ÿѫn giҧn nhҩt ÿѭӧc tiӃn hành nhѭ sau:
· Ĉҫu tiên chӑn phҫn tӱ có khóa nhӓ nhҩt trong n phҫn tӱ tӯ a[1] ÿӃn a[n] và hoán vӏ nó
Yӟi phҫn tӱ a[1].
· Chӑn phҫn tӱ có khóa nhӓ nhҩt trong n-1phҫn tӱ tӯ a[2] ÿӃn a[n] và hoán vӏ nó vӟi a[2].
· Tәng quát ӣ bѭӟc thӭ i, chӑn phҫn tӱ có khoá nhӓ nhҩt trong n-i+1 phҫn tӱ tӯ a[i] ÿӃn
a[n] và hoán vӏ nó vӟi a[i].
· Sau n-1 bѭӟc này thì mҧng ÿã ÿѭӧc sҳp xӃp.
Phѭѫng pháp này ÿѭӧc gӑi là phѭѫng pháp chӑn bӣi vì nó lһp lҥi quá trình chӑn phҫn tӱ nhӓ
nhҩt trong sӕ các phҫn tӱ chѭa ÿѭӧc sҳp.
Ví dө 2-1: Sҳp xӃp mҧng gӗm 10 mҭu tin có khóa là các sӕ nguyên: 5, 6, 2, 2, 10, 12, 9, 10, 9
và 3
Khoá
%ѭӟc
a[1] a[2] a[3] a[4] a[5] a[6] a[7] a[8] a[9] a[10]
Ban ÿҫu 5 6 2 2 10 12 9 10 9 3
%ѭӟc 1 2 6 5 2 10 12 9 10 9 3
%ѭӟc 2 2 5 6 10 12 9 10 9 3
%ѭӟc 3 3 6 10 12 9 10 9 5
%ѭӟc 4 5 10 12 9 10 9 6
%ѭӟc 5 6 12 9 10 9 10
%ѭӟc 6 9 12 10 9 10
%ѭӟc 7 9 10 12 10
%ѭӟc 8 10 12 10
%ѭӟc 9 10 12
.Ӄt quҧ 2 2 3 5 6 9 9 10 10 12
Hình 2-1: S̷p x͇p ch͕n
Chѭѫng trình:
procedure SelectionSort;
var
i,j,LowIndex: integer;
LowKey: KeyType;
begin
(1) for i := 1 to n-1 do begin
(2) LowIndex := i;
(3) LowKey := a[i].key;
(4) for j := i+1 to n do
(5) if a[j].key < LowKey then Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 18
begin
(6) LowKey := a[j].key;
(7) LowIndex := j;
end;
(8) Swap(a[i] , a[LowIndex]);
end;
end;
Ĉánh giá: Ph˱˯ng pháp s̷p x͇p ch͕n ḽy O(n2)ÿ͋ s̷p x͇p n ph̯n t͵.
Trѭӟc hӃt ta có thӫ tөc Swap lҩy mӝt hҵng thӡi gian nhѭÿã nói ӣ mөc II.1.3.
Các lӋnh (2), (3) ÿӅu lҩy O(1) thӡi gian. Vòng lһp for (4) - (7) thӵc hiӋn n-i lҫn, vì j chҥy tӯ
i+1 ÿӃn n, mӛi lҫn lҩy O(1), nên lҩy O(n-i) thӡi gian. Do ÿó thӡi gian tәng cӝng là:
II.2.2- Sҳp xӃp xen (Insertion Sort)
Giҧi thuұt
Trѭӟc hӃt ta xem phҫn tӱ a[1] là mӝt dãy ÿã có thӭ tӵ.
· Bѭӟc 1, xen phҫn tӱ a[2] vào danh sách ÿã có thӭ tӵ a[1] sao cho a[1], a[2] là mӝt danh
sách có thӭ tӵ.
· Bѭӟc 2, xen phҫn tӱ a[3] vào danh sách ÿã có thӭ tӵ a[1], a[2] sao cho a[1], a[2], a[3] là
Pӝt danh sách có thӭ tӵ.
· Tәng quát, bѭӟc i, xen phҫn tӱ a[i+1] vào danh sách ÿã có thӭ tӵ a[1],a[2],..a[i] sao cho
a[1], a[2],.. a[i+1] là mӝt danh sách có thӭ tӵ.
· Phҫn tӱÿang xét a[j] sӁÿѭӧc xen vào vӏ trí thích hӧp trong danh sách các phҫn tӱÿã
ÿѭӧc sҳp trѭӟc ÿó a[1],a[2],..a[j-1] bҵng cách so sánh khoá cӫa a[j] vӟi khoá cӫa a[j-1] ÿӭng ngay
trѭӟc nó. NӃu khoá cӫa a[j] nhӓ hѫn khoá cӫa a[j-1] thì hoán ÿәi a[j-1] và a[j] cho nhau và tiӃp tөc so
sánh khoá cӫa a[j-1] (lúc này a[j-1] chӭa nӝi dung cӫa a[j]) vӟi khoá cӫa a[j-2] ÿӭng ngay trѭӟc nó...
Ví dө 2-2: Sҳp xӃp mҧng gӗm 10 mҭu tin ÿã cho trong ví dө 2-1.
Khoá
%ѭӟc
a[1] a[2] a[3] a[4] a[5] a[6] a[7] a[8] a[9] a[10]
Ban ÿҫu 5 6 2 2 10 12 9 10 9 3
%ѭӟc 1 5 6
%ѭӟc 2 2 5 6
%ѭӟc 3 2 2 5 6
%ѭӟc 4 2 2 5 6 10
%ѭӟc 5 2 2 5 6 10 12 Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 19
%ѭӟc 6 2 2 5 6 9 10 12
%ѭӟc 7 2 2 5 6 9 10 10 12
%ѭӟc 8 2 2 5 6 9 9 10 10 12
%ѭӟc 9 2 2 3 5 6 9 9 10 10 12
Hình 2-2: S̷p x͇p xen
Chѭѫng trình
procedure InsertionSort;
var
i,j: integer;
begin
{1} for i := 2 to n do begin
{2} J := i;
{3} while (j>1) and (a[j].key < a[j-1].key) do begin
{4} swap(a[j], a[j-1]);
{5} j := j-1;
end;
end;
end;
Ĉánh giá: Ph˱˯ng pháp s̷p x͇p ch͕n ḽy O(n2)ÿ͋ s̷p x͇p n ph̯n t͵.
Ta thҩy các lӋnh (4) và (5) ÿӅu lҩy O(1). Vòng lһp (3) chҥy nhiӅu nhҩt i-1 lҫn, mӛi lҫn tӕn
O(1) nên (3) lҩy i-1 thӡi gian. LӋnh (2) và (3) là hai lӋnh nӕi tiӃp nhau, lӋnh (2) lҩy O(1) nên cҧ hai
OӋnh này lҩy i-1.
Vòng lһp (1) có i chҥy tӯ 2 ÿӃn n nên nӃu gӑi T(n) là thӡi gian ÿӇ sҳp n phҫn tӱ thì ta có
II.2.3- Sҳp xӃp nәi bӑt (Bubble Sort)
Giҧi thuұt
Chúng ta tѭӣng tѭӧng rҵng các mҭu tin ÿѭӧc lѭu trong mӝt mҧng dӑc, qua quá trình sҳp, mҭu
tin nào có khóa “nhҽ” sӁÿѭӧc nәi lên trên. Chúng ta duyӋt tòan mҧng, tӯ dѭӟi lên trên. NӃu hai phҫn
Wӱӣ cҥnh nhau mà không ÿúng thӭ tӵ tӭc là nӃu phҫn tӱ “nhҽ hѫn” lҥi nҵm dѭӟi thì phҧi cho nó “nәi
lên” bҵng cách ÿәi chӛ hai phҫn tӱ này cho nhau. Cө thӇ là:
· Bѭӟc 1: Xét các phҫn tӱ tӯ a[n] ÿӃn a[2], vӟi mӛi phҫn tӱ a[j], so sánh khoá cӫa nó vӟi
khoá cӫa phҫn tӱ a[j-1] ÿӭng ngay trѭӟc nó. NӃu khoá cӫa a[j] nhӓ hѫn khoá cӫa a[j-1] thì hoán ÿәi
a[j] và a[j-1] cho nhau.
· Bѭӟc 2: Xét các phҫn tӱ tӯ a[n] ÿӃn a[3], và làm tѭѫng tӵ nhѭ trên.
· Tәng quát ӣ bѭӟc thӭ i, ta sӁ xét các phҫn tӱ tӯ a[n] ÿӃn a[i+1].
Sau n bѭӟc ta thu ÿѭӧc mҧng có thӭ tӵ
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 20
Ví dө 2-3: Sҳp xӃp mҧng gӗm 10 mҭu tin ÿã cho trong ví dө 2-1.
Khoá
%ѭӟc
a[1] a[2] a[3] a[4] a[5] a[6] a[7] a[8] a[9] a[10]
Ban ÿҫu 5 6 2 2 10 12 9 10 9 3
%ѭӟc 1 2 5 6 2 3 10 12 9 10 9
%ѭӟc 2 2 5 6 3 9 10 12 9 10
%ѭӟc 3 3 5 6 9 9 10 12 10
%ѭӟc 4 5 6 9 9 10 10 12
%ѭӟc 5 6 9 9 10 10 12
%ѭӟc 6 9 9 10 10 12
%ѭӟc 7 9 10 10 12
%ѭӟc 8 10 10 12
%ѭӟc 9 10 12
.Ӄt quҧ 2 2 3 5 6 9 9 10 10 12
Hình 2-3: S̷p x͇p n͝i b͕t
Chѭѫng trình
procedure BubbleSort;
var
i,j: integer;
begin
(1) for i := 1 to n-1 do
(2) for j := n downto i+1 do
(3) if a[j].key < a[j-1].key then
(4) Swap(a[j],a[j-1]);
end;
Ĉánh giá: Ph˱˯ng pháp s̷p x͇p n͝i b͕t ḽy O(n2)ÿ͋ s̷p n ph̯n t͵.
Dòng lӋnh (3) lҩy mӝt hҵng thӡi gian. Vòng lһp (2) thӵc hiӋn (n-i) bѭӟc, mӛi bѭӟc lҩy O(1)
nên lҩy O(n-i) thӡi gian. Nhѭ vұy ÿӕi vӟi toàn bӝ chѭѫng trình ta có:
II.3- QUICKSORT
II.3.1- Ý tѭӣng
II.3.2- ThiӃt kӃ giҧi thuұt
II.3.3- Cài ÿһt giҧi thuұt
II.3.4- Thӡi gian thӵc hiӋn cӫa QuickSort
Trong phҫn này chúng ta sӁ nghiên cӭu mӝt giҧi thuұt sҳp xӃp ÿѭӧc dùng mӝt cách phә biӃn là
Quick Sort do A.R. Hoare phát minh vào năm 1960. Quick Sort ÿѭӧc ÿánh giá tӕt nhӡ vào sӵ phân tích
toán hӑc và các khҷng ÿӏnh vӅ khҧ năng cӫa nó. Quick Sort ÿã ÿѭӧc cҧi tiӃn ÿӇ trӣ thành phѭѫng pháp
ÿѭӧc chӑn trong các ӭng dөng sҳp xӃp thӵc tӃ khác nhau. Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 21
II.3.1- Ý tѭӣng
Chúng ta vүn xét mҧng a các mҭu tin a[1]..a[n]. Giҧ sӱ v là 1 giá trӏ khóa mà ta gӑi là chӕt
(pivot). Ta phân hoҥch dãy a[1]..a[n] thành hai mҧng con "bên trái" và "bên phҧi". Mҧng con "bên trái"
bao gӗm các phҫn tӱ có khóa nhӓ hѫn chӕt, mҧng con "bên phҧi" bao gӗm các phҫn tӱ có khóa lӟn hѫn
hoһc bҵng chӕt.
Sҳp xӃp mҧng con “bên trái” và mҧng con “bên phҧi” thì mҧng ÿã cho sӁÿѭӧc sҳp bӣi vì tҩt cҧ
các khóa trong mҧng con “bên trái “ ÿӅu nhӓ hѫn các khóa trong mҧng con “bên phҧi”.
ViӋc sҳp xӃp các mҧng con “bên trái” và “bên phҧi” cNJng ÿѭӧc tiӃn hành bҵng phѭѫng pháp
nói trên.
Mӝt mҧng chӍ gӗm mӝt phҫn tӱ hoһc gӗm nhiӅu phҫn tӱ có khóa bҵng nhau thì xem nhѭÿã có
thӭ tӵ.
II.3.2- ThiӃt kӃ giҧi thuұt
9ҩn ÿӅ chӑn chӕt
Chӑn khóa lӟn nhҩt trong hai phҫn tӱ có khóa khác nhau ÿҫu tiên kӇ tӯ trái qua. NӃu mҧng chӍ
Jӗm mӝt phҫn tӱ hay gӗm nhiӅu phҫn tӱ có khóa bҵng nhau thì không có chӕt.
9ҩn ÿӅ phҫn hoҥch
ĈӇ phân hoҥch mҧng ta dùng 2 "con nháy" L và R trong ÿó L tӯ bên trái và R tӯ bên phҧi, ta
cho L chҥy sang phҧi cho tӟi khi gһp phҫn tӱ có khóa chӕt và cho R chҥy sang trái cho tӟi khi gһp
phҫn tӱ có khóa < chӕt. Tҥi chӛ dӯng cӫa L và R nӃu L<R thì hoán vӏ a[L],a[R]. Lһp lҥi quá trình dӏch
sang phҧi, sang trái cӫa 2 "con nháy" L và R cho ÿӃn khi L>R. Khi ÿó L sӁ là ÿLӇm phân hoҥch, cө thӇ
là a[L] là phҫn tӱÿҫu tiên cӫa mҧng con “bên phҧi”.
Giҧi thuұt QuickSort
ĈӇ sҳp xӃp mҧng a[i]..a[j] ta tiӃn hành các bѭӟc sau:
· Xác ÿӏnh chӕt,
· Phân hoҥch mҧng ÿã cho thành hai mҧng con a[i]..a[k-1] và a[k]..a[j].
· Sҳp xӃp mҧng a[i]..a[k-1] (ĈӋ quy).
· Sҳp xӃp mҧng a[k]..a[j] (ĈӋ quy).
Quá trình ÿӋ quy sӁ dӯng khi không còn tìm thҩy chӕt.
Ví dө 2-4: Ta cҫn sҳp mӝt mҧng mà khóa là các sӕ nguyên ÿã ÿѭӧc trình bày trong ví dө 2-1.
Hai phҫn tӱÿҫu tiên có khóa khác nhau là 5 và 6, ta chӑn 6 làm chӕt và tiӃn hành phân hoҥch mҧng
ban ÿҫu làm hai mҧng con và ÿӋ quy cho hai mҧng con này.
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 22
II.3.3- Cài ÿһt giҧi thuұt
Hàm FindPivot
Ta thiӃt kӃ hàm FindPivot ÿӇ xác ÿӏnh trong dãy a[i]..a[j] xem có hay không hai phҫn tӱ có
khóa khác nhau. NӃu không tìm thҩy hai phҫn tӱ có khóa khác nhau thì trҧ vӅ giá trӏ 0 (không tìm thҩy
chӕt), ngѭӧc lҥi hàm trҧ vӅ giá trӏ là chӍ sӕ cӫa phҫn tӱ có khóa lӟn hѫn trong hai phҫn tӱ có khóa khác
nhau ÿҫu tiên. Khóa lӟn hѫn này sӁ trӣ thành phҫn tӱ chӕt mà ta sӁ xác ÿӏnh trong thӫ tөc QuickSort.
ĈӇ tiӋn so sánh ta sӱ dөng biӃn FirstKey ÿӇ lѭu giӳ khóa cӫa phҫn tӱÿҫu tiên trong mҧng
a[i]..a[j] (FirstKey chính là a[i].key).
Ta sӁ dùng mӝt chӍ sӕ k ÿӇ dò tìm trong mҧng a[i]..a[j], kӇ tӯ vӏ trí i+1 ÿӃn hӃt mҧng, mӝt phҫn
Wӱ a[k] mà a[k].key FirstKey. NӃu không tìm thҩy mӝt a[k] nhѭ thӃ thì hoһc là mҧng chӍ gӗm mӝt
phҫn tӱ hoһc gӗm nhiӅu phҫn tӱ có khóa bҵng nhau. Trong trѭӡng hӧp ÿó thì không tìm thҩy chӕt và
hàm FindPivot sӁ trҧ vӅ 0. Ngѭӧc lҥi ta sӁ phҧi xét xem a[k].key có lӟn hѫn FirstKey hay không, nӃu
ÿúng nhѭ thӃ thì chӕt sӁ là khóa cӫa a[k] và hàm FindPivot sӁ trҧ vӅ k, nӃu không thì hàm FindPivot sӁ
trҧ vӅ i.
Function FindPivot(i,j:integer): integer;
var
FirstKey : KeyType;
k : integer;
begin
k := i+1;
FirstKey := a[i].key;
while (k<=j) and (a[k].key = FirstKey) do k:= k+1;
if k > j then FindPivot := 0
else
if a[k].key > FirstKey then FindPivot := k
else FindPivot := i;
end;
Hàm Partition
Hàm Partition nhұn vào ba tham sӕ i, j và Pivot ÿӇ thӵc hiӋn viӋc phân hoҥch theo mҧng
a[i]..a[j] theo chӕt Pivot và trҧ vӅ giá trӏ l là chӍ sӕÿҫu tiên cӫa mҧng “bên phҧi”.
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 23
Hai con nháy L, R sӁÿѭӧc sӱ dөng ÿӇ thӵc hiӋn viӋc phân hoҥch nhѭÿã trình bày trong phҫn
II.3.2.
Function Partition(i,j:integer; pivot :KeyType):integer ;
var l,r : integer;
begin
l := i; {Ĉһt con nháy L ӣì bên trái}
r := j; {Ĉһt con nháy R ӣì bên phҧi}
while l <= r do begin
{L tiӃn sang phҧi}
while a[l].key < pivot do l := l+1;
{R tiӃn sang trái}
while a[r].key >= pivot do r := r-1;
if l <r then Swap(a[l],a[r]);
end;
Partition :=l;
end;
QuickSort
Bây giӡ chúng ta trình bày thӫ tөc cuӕi cùng có tên là QuickSort và chú ý rҵng ÿӇ sҳp xӃp
Pҧng A các record gӗm n phҫn tӱ cӫa kiӇu Recordtype ta chӍ cҫn gӑi QuickSort(1,n).
Ta sӁ sӱ dөng biӃn PivotIndex ÿӇ lѭu giӳ kӃt quҧ trҧ vӅ cӫa hàm FindPivot, nӃu biӃn
PivotIndex nhұn ÿѭӧc mӝt giá trӏ khác 0 thì mӟi tiӃn hành phân hoҥch mҧng. BiӃn Pivot sӁÿѭӧc sӱ
Gөng ÿӇ lѭu giӳ giá trӏ chӕt và biӃn k ÿӇ lѭu giӳ giá trӏ cӫa ÿLӇm phân hoҥch do hàm Partition trҧ vӅ.
Sau khia ÿã phân hoҥch xong ta sӁ gӑi ÿӋ quy QuickSort cho mҧng con “bên trái” a[i]..a[k-1] và mҧng
con “bên phҧi” a[k]..a[j].
procedure Quicksort(i,j:integer);
var
Pivot : KeyType;
PivotIndex, k : integer;
begin
(1) PivotIndex := FindPivot(i,j);
(2) if PivotIndex 0 then
begin
(3) Pivot := a[PivotIndex].key;
(4) k := Partition(i,j,Pivot);
(5) QuickSort(i,k-1);
(6) QuickSort(k,j);
end;
end;
II.3.4- Thӡi gian thӵc hiӋn cӫa QuickSort
QuickSort ḽy O(nlogn) thͥi gian ÿ͋ s̷p x͇p n ph̯n t͵ trong tr˱ͥng hͫp t͙t nh̭t và O(n2).
trong tr˱ͥng hͫp x̭u nh̭t.
Hàm Partition lҩy thӡi gian tӹ lӋ vӟi sӕ phҫn tӱ cӫa mҧng. Nhѭ vұy nӃu mҧng có n phҫn tӱ thì
Partition lҩy P(n)= n ÿѫn vӏ thӡi gian. Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 24
Gӑi T(n) là thӡi gian thӵc hiӋn cӫa QuickSort thì T(n) phҧi là tәng cӫa P(n) và thӡi gian
QuickSort ÿӋ quy cho hai mҧng con.
Giҧ sӱ các giá trӏ khóa cӫa mҧng khác nhau. Trong trѭӡng hӧp xҩu nhҩt là ta luôn chӑn phҧi
phҫn tӱ có khóa lӟn nhҩt làm chӕt, lúc bҩy giӡ viӋc phân hoҥch bӏ lӋch tӭc là mҧng bên phҧi chӍ gӗm
Pӝt phҫn tӱ chӕt, còn mҧng bên trái gӗm n-1 phҫn tӱ còn lҥi. Khi ÿó ta có thӇ thành lұp phѭѫng trình
ÿӋ quy nhѭ sau:
Giҧi phѭѫng trình này bҵng phѭѫng pháp truy hӗi
Ta có T(n) = T(n-1) + T(1) +n = T(n-1) + (n+1)
= [T(n-2) + T(1) +(n-1)] + (n+1) = T(n-2) + n + (n+1)
= [T(n-3) + T(1) +(n-2)] + n + (n+1) = T(n-3) +(n-1) + n + (n+1)
. . . . . . . . . . . . . . . . .
= T(n-i) + (n-i+2) + (n-i+3) + ... + n + (n+1) = T(n-i) +
Quá trình trên kӃt thúc khi i=n-1, khi ÿó ta có
Trong trѭӡng hӧp tӕt nhҩt khi ta chӑn ÿѭӧc chӕt sao cho hai mҧng con có kích thѭӟc bҵng
nhau và bҵng n/2. Lúc ÿó ta có phѭѫng trình ÿӋ quy nhѭ sau:
Giҧi phѭѫng trình ÿӋ quy này (xem I.4.2) ta ÿѭӧc T(n) = O(nlogn).
Ngѭӡi ta cNJng chӭng minh ÿѭӧc rҵng trong trѭӡng hӧp trung bình QuickSort lҩy T(n) =
O(nlogn).
II.4- HEAPSORT
II.4.1- Heap
II.4.2- Ý tѭӣng
II.4.3- ThiӃt kӃ và cài ÿһt giҧi thuұt
II.4.4- Phân tích HeapSort
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 25
II.4.1- Heap
Cây sҳp thӭ tӵ bӝ phұn hay còn gӑi là heap là cây nhӏ phân mà giá trӏ tҥi mӛi nút (khác nút lá)
ÿӅu không lӟn hѫn giá trӏ cӫa các con cӫa nó.
Ta có nhұn xét rҵng nút gӕc a[1] cӫa cây sҳp thӭ tӵ bӝ phұn có giá trӏ nhӓ nhҩt.
Ví dө 2-5: Cây sau là mӝt heap.
II.4.2- Ý tѭӣng
(1) Xem mҧng ban ÿҫu là mӝt cây nhӏ phân. Mӛi nút trên cây lѭu trNJ mӝt phҫn tӱ mҧng,
trong ÿó a[1] là nút gӕc và mӛi nút không là nút lá a[i] có con trái là a[2i] và con phҧi là a[2i+1]. Vӟi
cách tә chӭc này thì cây nhӏ phân thu ÿѭӧc sӁ có các nút trong là các nút a[1],..,a[n DIV 2]. Tҩt cҧ các
nút trong ÿӅu có 2 con, ngoҥi trӯ nút a[n DIV 2] có thӇ chӍ có mӝt con trái (trong trѭӡng hӧp n là mӝt
Vӕ chҹn).
(2) Sҳp xӃp cây ban ÿҫu thành mӝt heap căn cӭ vào giá trӏ khoá cӫa các nút.
(3) Hoán ÿәi a[1] cho cho phҫn tӱ cuӕi cùng.
(4) 6ҳp lҥi cây sau khi ÿã bӓÿi phҫn tӱ cuӕi cùng ÿӇ nó trӣ thành mӝt heap mӟi.
Lһp lҥi quá trình (3) và (4) cho tӟi khi cây rӛng ta sӁÿѭӧc mҧng sҳp theo thӭ tӵ giҧm.
II.4.3- ThiӃt kӃ và cài ÿһt giҧi thuұt
Thӫ tөc PushDown
Giҧ sӱ a[first],..,a[last] ÿã ÿúng vӏ trí (giá trӏ khoá tҥi mӛi nút nhӓ hѫn hoһc bҵng giá trӏ khoá
Wҥi các nút con cӫa nó) ngoҥi trӯ a[first]. PushDown dùng ÿӇÿҭy phҫn tӱ a[first] xuӕng ÿúng vӏ trí cӫa
nó trong cây (và có thӇ gây ra viӋc ÿҭy xuӕng các phҫn tӱ khác).
Xét a[first], có hai khҧ năng có thӇ xҧy ra:
· NӃu a[first] có khoá lӟn hѫn con trái cӫa nó (a[first].key > a[2*first].key) và khoá cӫa
con trái không lӟn hѫn khoá cӫa con phҧi (a[2*first].key a[2*first+1].key) thì hoán ÿәi a[first] cho
con trái a[2*first] cӫa nó, viӋc này có thӇ gây ra tình trҥng con trái sӁ không ÿúng vӏ trí nên phҧi xem
xét lҥi con trái.
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 26
· Ngѭӧc lҥi, nӃu a[first] có khoá lӟn hѫn khoá cӫa con phҧi cӫa nó (a[first].key >
a[2*first+1].key ) và khoá cӫa con phҧi nhӓ hѫn khoá cӫa con trái (a[2*first+1].key < a[2*first].key)
thì hoán ÿәi a[first] cho con phҧi a[2*first+1] cӫa nó, viӋc này có thӇ gây ra tình trҥng con phҧi sӁ
không ÿúng vӏ trí nên phҧi tiӃp tөc xem xét con phҧi.
· NӃu cҧ hai trѭӡng trên ÿӅu không xҭy ra thì a[first] ÿã ÿúng vӏ trí.
· Nhѭ trên ta thҩy viӋc ÿҭy a[first] xuӕng có thӇ gây ra viӋc ÿҭy xuӕng mӝt sӕ phҫn tӱ
khác, nên tәng quát là ta sӁ xét viӋc ÿҭy xuӕng cӫa mӝt phҫn tӱ a[r] bҩt kǤ, bҳt ÿҫu tӯ a[first].
procedure PushDown(first,last:integer);
var r:integer;
begin
r:= first; {Xét nút a[first] trѭӟc hӃt}
while r <= last div 2 do
{Trong khi a[r] còn là nút trong}
if last = 2*r then begin {nút r chӍ có con trái }
if a[r].key > a[last].key then swap(a[r],a[last]);
r:=last;
end
else
if (a[r].key>a[2*r].key)and(a[2*r].key a[2*r+1].key)then begin
swap(a[r],a[2*r]);
r := 2*r ; {Xét tiӃp nút con trái }
end
else
if (a[r].key > a[2*r+1].key) and (a[2*r+1].key < a[2*r].key) then begin
swap(a[r],a[2*r+1]);
r := 2*r+1 ; {Xét tiӃp nút con phҧi }
end
else
r := last; {Nút r ÿã ÿúng vӏ trí }
end;
Thӫ tөc HeapSort
· ViӋc sҳp xӃp cây ban ÿҫu thành mӝt heap ÿѭӧc tiӃn hành bҵng cách sӱ dөng thӫ tөc
PushDown ÿӇÿҭy tҩt cҧ các nút trong chѭa ÿúng vӏ trí xuӕng ÿúng vӏ trí cӫa nó, khӣi ÿҫu tӯ nút a[n
DIV 2], lҫn ngѭӧc tӟi gӕc.
· Lһp lҥi viӋc hoán ÿәi a[1] cho a[i], sҳp xӃp cây a[1]..a[i-1] thành heap, i chҥy tӯ n ÿӃn 2.
procedure HeapSort;
var
i:integer;
begin
(1) for i := (n div 2) downto 1 do
(2) PushDown(i,n);
(3) for i := n downto 2 do begin
(4) swap(a[1],a[i]); Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 27
(5) pushdown(1,i-1);
end;
end;
Ví dө 2-6: Sҳp xӃp mҧng bao gӗm 10 phҫn tӱ có khoá là các sӕ nguyên nhѭ trong các ví dө
trѭӟc:
Khoá a[1] a[2] a[3] a[4] a[5] a[6] a[7] a[8] a[9] a[10]
Ban ÿҫu 5 6 2 2 10 12 9 10 9 3
Mҧng này ÿѭӧc xem nhѭ là mӝt cây nhӏ phân ban ÿҫu nhѭ sau:
Trong cây trên, giá trӏ ghi trong các nút là khoá cӫa các phân tӱ mҧng, giá trӏ ghi bên ngoài các
nút là chӍ sӕ cӫa các phҫn tӱ mҧng.
ViӋc sҳp xӃp cây này thành mӝt heap sӁ bҳt ÿҫu tӯ viӋc ÿҭy xuӕng nút a[5] (vì 5 = 10 DIV 2)
Xét nút 5 ta thҩy a[5] chӍ có mӝt con trái và giá trӏ khóa tѭѫng ӭng cӫa nó lӟn hѫn con trái cӫa
nó nên ta ÿәi hai nút này cho nhau và do con trái cӫa a[5] là a[10] là mӝt nút lá nên viӋc ÿҭy xuӕng cӫa
a[5] kӃt thúc.
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 28
Nút 4 và nút 3 ÿã ÿúng vӏ trí nên không phҧi thӵc hiӋn sӵ hoán ÿәi. Tҥi nút 2, giá trӏ khóa cӫa
nó lӟn hѫn khoá con trái và khoá cӫa con trái nhӓ hѫn khoá cӫa con phҧi nên ta hóan ÿәi nút 2 cho con
trái cӫa nó (nút 4), sau khi hoán ÿәi, ta xét lҥi nút 4, thҩy nó vүn ÿúng vӏ trí nên kӃt thúc viӋc ÿҭy
xuӕng cӫa nút 2.
Cuӕi cùng ta xét nút 1, ta thҩy giá trӏ khoá cӫa nút 1 lӟn hѫn khoá cӫa con trái và con trái có
khoá bҵng khoá cӫa con phҧi nên hóan ÿәi nút 1 cho con trái cӫa nó (nút 2).
Sau khi thӵc hiӋn phép hóan ÿәi nút 1 cho nút 2, ta thҩy nút 2 có giá trӏ khoá lӟn hѫn khoá cӫa
con phҧi cӫa nó (nút 5) và con phҧi có khoá nhӓ hѫn khoá cӫa con trái nên phҧi thӵc hiӋn phép hoán
ÿәi nút 2 cho nút 5. Xét lҥi nút 5 thì nó vүn ÿúng vӏ trí nên ta ÿѭӧc cây mӟi trong hình 2-9.
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 29
Cây này là mӝt heap tѭѫng ӭng vӟi mҧng
Khoá a[1] a[2] a[3] a[4] a[5] a[6] a[7] a[8] a[9] a[10]
Heap 2 3 2 6 5 12 9 10 9 10
Tӯ heap ÿã có ӣ trên, hoán ÿәi a[1] cho a[10] ta có a[10] là nút có khóa nhӓ nhҩt, cҳt bӓ nút
a[10] ra khӓi cây. Nhѭ vұy phҫn cuӕi mҧng chӍ gӗm mӝt phҫn tӱ a[10] ÿã ÿѭӧc sҳp.
Thӵc hiӋn viӋc ÿҭy a[1] xuӕng ÿúng vӏ trí cӫa nó trong cây a[1]..a[9] ta ÿѭӧc cây:
Hoán ÿәi a[1] cho a[9] và cҳt a[9] ra khӓi cây. Ta ÿѭӧc phҫn cuӕi mҧng bao gӗm hai phҫn tӱ
a[9]..a[10] ÿã ÿѭӧc sҳp. Thӵc hiӋn viӋc ÿҭy a[1] xuӕng ÿúng vӏ trí cӫa nó trong cây a[1]..a[8] ta ÿѭӧc
cây
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 30
TiӃp tөc quá trình trên ta sӁÿѭӧc mӝt mҧng có thӭ tӵ giҧm.
II.4.4- Phân tích HeapSort
Thӡi gian thӵc hiӋn cӫa HeapSort là O(n logn)
Trong thӫ tөc PushDown mӛi lҫn lһp, r có ít nhҩt 2 giá trӏ, vì r bҳt ÿҫu bҵng first nên sau i lҫn
Oһp, chúng ta có r first * 2i. Thӫ tөc dӯng khi r > last/2 do vұy khi thӫ tөc dӯng thì ta có first*2i >
last/2 hay 2i+1 > last/first. Suy ra i > log(last/first) - 1 tӭc là sӕ lҫn lһp nhiӅu nhҩt cӫa thӫ tөc PushDown
là log(last/first).
Vì first 1 và last n trong mӛi lҫn gӑi PushDown cӫa thӫ tөc HeapSort tҥi dòng (2) hoһc (5)
nên sӕ lҫn lһp logn, mӛi bѭӟc lһp lҩy mӝt thӡi gian O(1) nên thӡi gian thӵc hiӋn cӫa PushDown là
O(logn).
Trong thӫ tөc HeapSort dòng lӋnh (1)-(2) lһp n/2 lҫn mà mӛi lҫn lҩy O(logn) nên thӡi gian
thӵc hiӋn (1)-(2) là O(n logn). Vòng lһp (3)-(4)-(5) lһp n-1 lҫn, mӛi lҫn lҩy O(logn) nên thӡi gian thӵc
hiӋn (3)-(4)-(5) là O(n logn). Tóm lҥi thӡi gian thӵc hiӋn HeapSort là O(n logn)
II.5- BINSORT
II.5.1- Giҧi thuұt
II.5.2- Phân tích Bin Sort
II.5.3- Sҳp xӃp tұp giá trӏ có khoá lӟn
II.5.1- Giҧi thuұt
Nói chung các giҧi thuұt ÿã trình bày ӣ trên ÿӅu có ÿӝ phӭc tҥp là O(n2) hoһc O(nlogn). Tuy
nhiên khi kiӇu dӳ liӋu cӫa trѭӡng khoá là mӝt kiӇu ÿһc biӋt , viӋc sҳp xӃp có thӇ chӍ chiӃm O(n) thӡi
gian. Sau ÿây ta sӁ xét mӝt sӕ trѭӡng hӧp.
Trѭӡng hӧp ÿѫn giҧn: Giҧ sӱ ta phҧi sҳp xӃp mӝt mҧng A gӗm n phҫn tӱ có khoá là các sӕ
nguyên có giá trӏ khác nhau và là các giá trӏ tӯ 1 ÿӃn n. Ta sӱ dөng B là mӝt mҧng cùng kiӇu vӟi A và
phân phӕi vào phҫn tӱ b[j] mӝt phҫn tӱ a[i] mà a[i].key = j. Khi ÿó mҧng B lѭu trӳ kӃt quҧÿã ÿѭӧc sҳp
[Ӄp cӫa mҧng A.
Ví dө 2-7: Sҳp xӃp mҧng A gӗm 10 phҫn tӱ có khoá là các sӕ nguyên có giá trӏ là các sӕ 4, 5,
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 31
2, 1, 7, 8, 10, 9, 6 và 3
Ta sӱ dөng mҧng B có cùng kiӇu vӟi A và thӵc hiӋn viӋc phân phӕi a[1] vào b[4] vì a[1].key =
4, a[2] vào b[5] vì a[2].key = 5, a[3] vào b[2] vì a[3].key = 2,...
ĈӇ thӵc hiӋn viӋc phân phӕi này ta chӍ cҫn mӝt lӋnh lһp:
for i:=1 to n do B[A[i].key] := A[i]
Ĉây cNJng là lӋnh chính trong chѭѫng trình sҳp xӃp. LӋnh này lҩy O(n) thӡi gian.
Các phҫn tӱ b[j] ÿѭӧc gӑi là các bin và phѭѫng pháp sҳp xӃp này ÿѭӧc gӑi là bin sort.
Trѭӡng hӧp tәng quát: Là trѭӡng hӧp có thӇ có nhiӅu phҫn tӱ có chung mӝt giá trӏ khóa,
chҷng hҥn ÿӇ sҳp mӝt mҧng A có n phҫn tӱ mà các giá trӏ khóa cӫa chúng là các sӕ nguyên lҩy giá trӏ
trong khoҧng 1..m vӟi m n. Trong trѭӡng hӧp này ta không thӇ sӱ dөng các phҫn tӱ cӫa mҧng B làm
bin ÿѭӧc vì nӃu có hai phҫn tӱ cӫa mҧng A có cùng mӝt khoá thì không thӇ lѭu trӳ trong cùng mӝt bin.
ĈӇ giҧi quyӃt sӵÿөng ÿӝ này ta chuҭn bӏ mӝt cҩu trúc có m bin, mӛi bin có thӇ lѭu trӳ nhiӅu
Kѫn mӝt phҫn tӱ. Cө thӇ là bin thӭ j sӁ lѭu các phҫn tӱ có khóa là j (1 j m) sau ÿó ta sӁ nӕi các bin
Oҥi vӟi nhau ÿӇÿѭӧc mӝt dãy các phҫn tӱÿѭӧc sҳp.
Cách tӕt nhҩt là ta thiӃt kӃ mӛi bin là mӝt danh sách liên kӃt cӫa các phҫn tӱ mà mӛi phҫn tӱ
có kiӇu RecordType. Ta sӁ gӑi kiӇu cӫa danh sách này là ListType.
Ta có thӇ tҥo kiӇu ListType bҵng cách ghép RecordType vӟi mӝt con trӓÿӇ trӓ tӟi phҫn tӱ kӃ
tiӃp.
Lҩy B là mӝt mҧng kiӇu Array[KeyType] of ListType. Nhѭ vұy B là mҧng các bin, mӛi bin là
Pӝt danh sách. B ÿѭӧc ÿánh chӍ sӕ bӣi KeyType, nhѭ thӃ có ít nhҩt mӝt bin cho mӛi giá trӏ khoá.
Ta vүn sӁ phân phӕi phҫn tӱ a[i] vào bin b[j] nӃu j = a[i]key. Dƭ nhiên mӛi bin b[j] có thӇ chӭa
nhiӅu phҫn tӱ cӫa mҧng A. Các phҫn tӱ mӟi sӁÿѭӧc ÿѭa vào cuӕi danh sách b[j].
Sau khi tҩt cҧ các phҫn tӱ cӫa mҧng A ÿã ÿѭӧc phân phӕi vào trong các bin, công viӋc cuӕi
cùng là ta phҧi nӕi các bin lҥi vӟi nhau, ta sӁÿѭӧc mӝt danh sách có thӭ tӵ. Ta sӁ dùng thӫ tөc
concatenate(L1,L2) ÿӇ nӕi hai danh sách L1, L2. Nó thay thӃ danh sách L1 bӣi danh sách nӕi L1L2. ViӋc
Qӕi sӁÿѭӧc thӵc hiӋn bҵng cách gҳn con trӓ cӫa phҫn tӱ cuӕi cùng cӫa L1 vào ÿҫu cӫa L2. Ta biӃt rҵng
ÿӇÿӃn ÿѭӧc phҫn tӱ cuӕi cùng cӫa danh sách liên kӃt L1 ta phҧi duyӋt qua tҩt cҧ các phҫn tӱ cӫa nó.
ĈӇ cho có hiӋu quҧ, ta thêm mӝt con trӓ nӳa, trӓÿӃn phҫn tӱ cuӕi cùng cӫa mӛi danh sách, ÿLӅu này
giúp ta ÿi thҷng tӟi phҫn tӱ cuӕi cùng mà không phҧi duyӋt qua toàn bӝ danh sách.
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 32
Hình 2-13 minh hӑa viӋc nӕi hai danh sách.
Sau khi nӕi thì header và end cӫa danh sách L2 không còn tác dөng nӳa.
Ví dө 2-8: Sҳp xӃp mҧng A gӗm 10 phҫn tӱ có khoá là các sӕ nguyên có giá trӏ là các sӕ 2, 4,
1, 5, 4, 2, 1, 4, 1, 5.
A a[1] a[2] a[3] a[4] a[5] a[6] a[7] a[8] a[9] a[10]
Khoá cӫa A 2 4 1 5 4 2 1 4 1 5
Ta thҩy các giá trӏ khoá nҵm trong khoҧng 1..5. Ta tә chӭc mӝt mҧng B gӗm 5 phҫn tӱ, mӛi
phҫn tӱ là mӝt con trӓ, trӓÿӃn mӝt danh sách liên kӃt .
Chѭѫng trình sӱ dөng cҩu trúc danh sách liên kӃt làm các bin
VAR
A: array[1..n] of RecordType; Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 33
B: array[keytype] of ListType;
{Ta giҧ thiӃt keytype là kiӇu miӅn con 1..m }
procedure BinSort;
var
i:integer;
j: KeyType;
begin
{1}for i:=1 to n do
INSERT(A[i], END(B[A[i].key]), B[A[i}.key]);
{2}for j:= 2 to m do
CONCATENATE(B[1], B[j]);
end;
II.5.2- Phân tích Bin Sort
Bin sort ḽy O(n) thͥi gian ÿ͋ s̷p x͇p m̫ng g͛m n ph̯n t͵.
Trѭӟc hӃt thӫ tөc INSERT cҫn mӝt thӡi gian O(1) ÿӇ xen mӝt phҫn tӱ vào trong danh sách. Do
cách tә chӭc danh sách có giNJ con trӓÿӃn phҫn tӱ cuӕi cùng nên viӋc nӕi hai danh sách bҵng thӫ tөc
CONCATENATE cNJng chӍ mҩt O(1) thӡi gian. Ta thҩy vòng lһp {1} thӵc hiӋn n lҫn, mӛi lҫn tӕn O(1)
= 1 nên lҩy O(n) ÿѫn vӏ thӡi gian. Vòng lһp {2} thӵc hiӋn m-1 lҫn, mӛi lҫn O(1) nên tӕn O(m) ÿѫn vӏ
thӡi gian. Hai lӋnh {1} và {2} nӕi tiӃp nhau nên thӡi gian thӵc hiӋn cӫa BinSort là T(n) = O(max(n,m))
= O(n) vì m n.
II.5.3- Sҳp xӃp tұp giá trӏ có khoá lӟn
NӃu m sӕ các khoá không lӟn hѫn n sӕ các phҫn tӱ cҫn sҳp xӃp, khi ÿó O(max(n,m)) thӵc sӵ là
O(n). NӃu giҧ sӱ m = n2 khi ÿó O(max(n, n2)) là O(n2) nhѭ vұy Bin sort lҩy O(n2) thӡi gian.
Tuy nhiên ta vүn có thӇ tәng quát hoá kӻ thuұt bin sort ÿӇ nó vүn lҩy O(n) thӡi gian.
Giҧ sӱ ta cҫn sҳp xӃp n phҫn tӱ có các giá trӏ khoá thuӝc 0..n2-1.
Ta sӁ sӱ dөng n bin B[0], B[1],...B[n-1] và tiӃn hành viӋc sҳp xӃp trong hai kǤ.
KǤ 1: Phân phӕi phҫn tӱ a[i] vào bin B[j] mà j = a[i].key MOD n.
KǤ 2: Phân phӕi các phân tӱ trong danh sách kӃt quҧ cӫa kǤ 1 vào các bin. Phҫn tӱ a[i] sӁÿѭӧc
phân phӕi vào bin B[j] mà j = a[i].key DIV n.
Chú ý rҵng trong cҧ hai kǤ, ta xen các phҫn tӱ mӟi ÿѭӧc phân phӕi vào cuӕi danh sách.
Ví dө 2-9: Cҫn sҳp xӃp mҧng gӗm 10 phҫn tӱ có khoá là các sӕ nguyên: 36, 9, 0, 25, 1, 49, 64,
16, 81 và 4.
Ta sӱ dөng 10 bin ÿѭӧc ÿánh sӕ tӯ 0 ÿӃn 9. KǤ mӝt ta phân phӕi phҫn tӱ a[i] vào bin có chӍ sӕ
a[i].key MOD 10. Nӕi các bin lҥi vӟi nhau ta ÿѭӧc danh sách có khóa là: 0 1 81 64 4 25 36 16 9 49. KǤ
hai sӱ dөng kӃt quҧ cӫa kǤ 1 ÿӇ sҳp tiӃp. Phân phӕi phҫn tӱ a[i] vào bin có chӍ sӕ a[i].key DIV 10. Nӕi
các bin lҥi vӟi nhau ta ÿѭӧc danh sách có thӭ tӵ.
.Ǥ 1 KǤ 2 Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 34
Bin Bin
0 0 0 0 1 4 9
1 1 81 1 16
2 2 25
3 3 36
4 64 4 4 49
5 25 5
6 36 16 6 64
7 7
8 8 81
9 9 49 9
Hình 2-13: S̷p x͇p theo hai kǤ
Theo sӵ phân tích giҧi thuұt Bin Sort thì mӛi kǤ lҩy O(n) thӡi gian, hai kǤ này nӕi tiӃp nhau
nên thӡi gian tәng cӝng là O(n).
Chӭng minh giҧi thuұt ÿúng
ĈӇ thҩy tính ÿúng ÿҳn cӫa giҧi thuұt ta xem các các giá trӏ khóa nguyên tӯ 0 ÿӃn n2-1 nhѭ các
Vӕ có hai chӳ sӕ trong hӋÿӃm cѫ sӕ n. Xét hai sӕ k = sn + t và l = un + v trong ÿó s, t, u, v là các sӕ
0..n-1. Giҧ sӱ k < l, ta cҫn chӭng minh rҵng sau 2 kǤ sҳp thì k phҧi ÿӭng trѭӟc l.
Vì k < l nên s u. NӃu s < u thì k ÿӭng trѭӟc l trong danh sách kӃt qӫa vì k ÿѭӧc sҳp vào bin
b[s] và l ÿѭӧc sҳp vào bin b[u] mà b[s] ÿӭng trѭӟc b[u]. NӃu s=u thì t<v. Sau kǤ 1 thì k ÿӭng trѭӟc l, vì
k ÿѭӧc sҳp vào trong bin b[t] và l trong bin b[v]. ĈӃn kǤ 2 mһc dù cҧ k và l ÿӅu ÿѭӧc sҳp vào trong bin
b[s], nhѭng k ÿѭӧc xen vào trѭӟc l nên kӃt quҧ là k ÿӭng trѭӟc l.
Chú ý 7ӯ chӭng minh trên ta thҩy ÿӇ sҳp các phҫn tӱ có khóa là các sӕ nguyên (hӋÿӃm cѫ sӕ
10) tӯ 0 ÿӃn 99 ta dùng 10 bin có chӍ sӕ tӯ 0 ÿӃn 9. ĈӇ sҳp các phҫn tӱ có khóa là các sӕ nguyên tӯ 0
ÿӃn 999 ta dùng 100 bin có chӍ sӕ tӯ 0 ÿӃn 99...
Bài 1: Sɬp xɼp mɠng g͓m 12 phɤn tͭ có khóa là các s͑ nguyên : 5, 15, 12, 2, 10, 12, 9, 1, 9, 3, 2, 3
Eɮng cách sͭ dͥng:
a) Sɬp xɼp ch͍n.
b) Sɬp xɼp xen.
c) Sɬp xɼp n͕i b͍t.
d) QuickSort.
e) HeapSort.
Bài 2: Có m͙t biɼn thʀ cͧa sɬp xɼp ch͍n nhɉ sau: Trong bɉ͛c thͩ i ta ch͍n m͙t phɤn tͭ có
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 35
khóa nh͏ nhɢt và m͙t phɤn tͭ có khóa l͛n nhɢt trong a[i]...a[n-i+1] và hóan ÿ͕i phɤn tͭ nh͏ nhɢt
cho a[i] và phɤn tͭ l͛n nhɢt cho a[n-i+1]. Hãy viɼt thͧ tͥc sɬp xɼp ch͍n theo giɠi thuɪt này và tính
th͝i gian thͱc hiʄn.
Bài 3: Viɼt thͧ tͥc sɬp xɼp tr͙n (xem giɠi thuɪt thô trong chɉɇng 1).
Bài 4: Có m͙t biɼn thʀ cͧa QuickSort nhɉ sau: Ch͍n ch͑t là khóa cͧa phɤn tͭ nh͏ nhɢt
trong hai phɤn tͭ có khóa khác nhau ÿɤu tiên. Mɠng con bên trái g͓m các phɤn tͭ có khóa nh͏ hɇn
hoɴc bɮng ch͑t, mɠng con bên phɠi g͓m các phɤn tͭ có khóa l͛n hɇn ch͑t. Hãy viɼt lɞi các thͧ tͥc
Fɤn thiɼt cho biɼn thʀ này.
Bài 5: M͙t biɼn thʀ khác cͧa QuickSort là ch͍n khóa cͧa phɤn tͭÿɤu tiên làm ch͑t. Hãy
viɼt lɞi các thͧ tͥc cɤn thiɼt cho biɼn thʀ này.
Bài 6: Hãy viɼt lɞi thͧ tͥc PushDown trong HeapSort ÿʀ có thʀ sɬp xɼp theo thͩ tͱ tăng.
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 36
1. Mөc tiêu
2. KiӃn thӭc cѫ bҧn cҫn có ÿӇ hӑc chѭѫng này
3. Tài liӋu tham khҧo có liên quan ÿӃn chѭѫng
4. Nӝi dung:
III.1 - Giҧi thuұt chia ÿӇ trӏ
III.2 - Quy hoҥch ÿӝng
III.3 - Kӻ thuұt "tham ăn"
III.4 - Kӻ thuұt quay lui
III.5 - Kӻ thuұt tìm kiӃm ÿӏa phѭѫng
5. Vҩn ÿӅ nghiên cӭu cӫa trang kӃ tiӃp
Nói chung khi thiӃt kӃ mӝt giҧi thuұt chúng ta thѭӡng dӵa vào mӝt sӕ kӻ thuұt nào ÿó. Chѭѫng
này sӁ trình bày mӝt sӕ kӻ thuұt quan trӑng ÿӇ thiӃt kӃ giҧi thuұt nhѭ: Chia ÿӇ trӏ (Divide-and-
Conquer), quy hoҥch ÿӝng (dynamic programming), kӻ thuұt tham ăn (greedy techniques), quay lui
(backtracking) và tìm kiӃm ÿӏa phѭѫng (local search). Các kӻ thuұt này ÿѭӧc áp dөng vào mӝt lӟp
Uӝng các bài toán, trong ÿó có nhӳng bài toán nәi tiӃng nhѭ bài toán tìm ÿѭӡng ÿi ngҳn nhҩt cӫa ngѭӡi
giao hàng, bài toán cây phӫ tӕi tiӇu...
III.1- GIҦI THUҰT CHIA Ĉӆ TRӎ
III.1.1- Nӝi dung kӻ thuұt
III.1.2- Nhìn nhұn lҥi giҧi thuұt MergeSort và QuickSort
III.1.3- Bài toán nhân các sӕ nguyên lӟn
III.1.4- XӃp lӏch thi ÿҩu thӇ thao
III.1.5- Bài toán con cân bҵng
III.1.1- Nӝi dung kӻ thuұt
Có thӇ nói rҵng kӻ thuұt quan trӑng nhҩt, ÿѭӧc áp dөng rӝng rãi nhҩt ÿӇ thiӃt kӃ các giҧi thuұt
có hiӋu quҧ là kӻ thuұt "chia ÿӇ trӏ" (divide and conquer). Nӝi dung cӫa nó là: ĈӇ giҧi mӝt bài toán
kích thѭӟc n, ta chia bài toán ÿã cho thành mӝt sӕ bài toán con có kích thѭóc nhӓ hѫn. Giҧi các bài
toán con này rӗi tәng hӧp kӃt quҧ lҥi ÿӇÿѭӧc lӡi giҧi cӫa bài toán ban ÿҫu. Ĉӕi vӟi các bài toán con,
chúng ta lҥi sӱ dөng kӻ thuұt chia ÿӇ trӏÿӇ có ÿѭӧc các bài toán kích thѭӟc nhӓ hѫn nӳa. Quá trình trên
VӁ dүn ÿӃn nhӳng bài toán mà lӡi giҧi chúng là hiӇn nhiên hoһc GӉ dàng thӵc hiӋn, ta gӑi các bài toán
này là bài toán cѫ sӣ.
Tóm lҥi kӻ thuұt chia ÿӇ trӏ bao gӗm hai quá trình: Phân tích bài toán ÿã cho thành các bài
toán cѫ sӣ và Wәng hӧp kӃt quҧ tӯ bài toán cѫ sӣÿӇ có lӡi giҧi cӫa bài toán ban ÿҫu. Tuy nhiên ÿӕi vӟi
Pӝt sӕ bài toán, thì quá trình phân tích ÿã chӭa ÿӵng viӋc tәng hӧp kӃt quҧ do ÿó nӃu chúng ta ÿã giҧi
xong các bài toán cѫ sӣ thì bài toán ban ÿҫu cNJng ÿã ÿѭӧc giҧi quyӃt. Ngѭӧc lҥi có nhӳng bài toán mà
quá trình phân tích thì ÿѫn giҧn nhѭng viӋc tәng hӧp kӃt quҧ lҥi rҩt khó khăn. Trong các phҫn tiӃp sau
ta sӁ trình bày mӝt sӕ ví dөÿӇ thҩy rõ hѫn ÿLӅu này.
.ӻ thuұt này sӁ cho chúng ta mӝt giҧi thuұt ÿӋ quy mà viӋc xác ÿӏnh ÿӝ phӭc tҥp cӫa nó sӁ
phҧi giҧi mӝt phѭѫng trình ÿӋ quy nhѭ trong chѭѫng I ÿã trình bày.
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 37
III.1.2 Nhìn nhұn lҥi giҧi thuұt MergeSort và QuickSort
Hai giҧi thuұt sҳp xӃp ÿã ÿѭӧc trình bày trong các chѭѫng trѭӟc (MergeSort trong chѭѫng I và
QuickSort trong chѭѫng II) thӵc chҩt là ÿã sӱ dөng kӻ thuұt chia ÿӇ trӏ.
9ӟi MergeSort, ÿӇ sҳp mӝt danh sách L gӗm n phҫn tӱ, chúng ta chia L thành hai danh sách
con L1 và L2 mӛi danh sách có n/2 phҫn tӱ. Sҳp xӃp L1, L2 và trӝn hai danh sách ÿã ÿѭӧc sҳp này ÿӇ
ÿѭӧc mӝt danh sách có thӭ tӵ. Quá trình phân tích ӣÿây là quá trình chia ÿôi mӝt danh sách, quá trình
này sӁ dүn ÿӃn bài toán sҳp xӃp mӝt danh sách có ÿӝ daì bҵng 1, ÿây chính là bài toán cѫ sӣ vì viӋc sҳp
[Ӄp danh sách này là “không làm gì cҧ”. ViӋc tәng hӧp các kӃt quҧӣÿây là “trӝün 2 danh sách ÿã
ÿѭӧc sҳp ÿӇÿѭӧc mӝt danh sách có thӭ tӵ”.
9ӟi QuickSort, ÿӇ sҳp xӃp mӝt danh sách gӗm n phҫn tӱ, ta tìm mӝt giá trӏ chӕt và phân hoҥch
danh sách ÿã cho thành hai danh sách con “bên trái” và “bên phҧi “. Sҳp xӃp “bên trái” và “bên phҧi”
thì ta ÿѭӧc danh sách có thӭ tӵ. Quá trình phân chia sӁ dүn ÿӃn các bài toán sҳp xӃp mӝt danh sách chӍ
Jӗm mӝt phҫn tӱ hoһc gӗm nhiӅu phҫn tӱ có khoá bҵng nhau, ÿó chính là các bài toán cѫ sӣ, vì bҧn
thân chúng ÿã có thӭ tӵ rӗi. Ӣÿây chúng ta cNJng không có viӋc tәng hӧp kӃt quҧ mӝt cách tѭӡng
minh, vì viӋc ÿó ÿã ÿѭӧc thӵc hiӋn trong quá trình phân hoҥch.
III.1.3- Bài toán nhân các sӕ nguyên lӟn
Xét bài toán nhân hai sӕ nguyên n chӳ sӕ X và Y. Theo giҧi thuұt nhân hai sӕ thông thѭӡng thì
Fҫn n2 phép nhân và n phép cӝng nên tӕn O(n2) thӡi gian. Áp dөng kӻ thuұt "chia ÿӇ trӏ" vào phép nhân
các sӕ nguyên, ta chia mӛi sӕ nguyên X và Y thành các sӕ nguyên có n/2 chӳ sӕ. ĈӇÿѫn giҧn ta giҧ sӱ
n là luӻ thӯa cӫa 2
X = A10n/2 + B
Y = C10n/2 + D
Trong ÿó A, B, C, D là các sӕ nguyên có n/2 chӳ sӕ.
Chҷng hҥn vӟi X = 1234 thì A = 12 và B = 34 bӣi vì X = 12 *102 + 34.
Tích cӫa X và Y có thӇÿѭӧc viӃt thành: XY = AC10n+(AD + BC)10n/2 + BD (III.1)
9ӟi mӛi sӕ có n/2 chӳ sӕ, chúng ta lҥi tiӃp tөc phân tích theo cách trên, quá trình phân tích sӁ
Gүn ÿӃn bài toán cѫ sӣ là nhân các sӕ nguyên chӍ gӗm mӝt chӳ sӕ mà ta dӉ dàng thӵc hiӋn. ViӋc tәng
Kӧp kӃt quҧ chính là thӵc hiӋn các phép toán theo công thӭc (III.1).
Theo (III.1) thì chúng ta phҧi thӵc hiӋn 4 phép nhân các sӕ nguyên n/2 chӳ sӕ (AC, AD, BC,
BD), sau ÿó tәng hӧp kӃt quҧ bҵng 3 phép cӝng các sӕ nguyên n chӳ sӕ và 2 phép nhân vӟi 10n và
10n/2.
Các phép cӝng các sӕ nguyên n chӳ sӕ dƭ nhiên chӍ cҫn O(n). Phép nhân vӟi 10n có thӇ thӵc
hiӋn mӝt cách ÿѫn giҧn bҵng cách thêm vào n chӳ sӕ 0 và do ÿó cNJng chӍ lҩy O(n). Gӑi T(n) là thӡi
gian ÿӇ nhân hai sӕ nguyên, mӛi sӕ có n chӳ sӕ thì tӯ (III.1) ta có:
T(1) = 1
T(n) = 4T(n/2) + cn (III.2) Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 38
Giҧi (III.1) ta ÿѭӧc T(n) = O(n2). Nhѭ vұy thì chҷng cҧi tiӃn ÿѭӧc chút nào so vӟi giҧi thuұt
nhân hai sӕ bình thѭӡng. ĈӇ cҧi thiӋn tình hình, chúng ta có thӇ viӃt lҥi (III.1) thành dҥng:
XY = AC10n + [(A-B)(D-C) + AC + BD] 10n/2+ BD (III.3)
Công thӭc (III.3) chӍÿòi hӓi 3 phép nhân cӫa các sӕ nguyên n/2 chӳ sӕ là: AC, BD và (A-
B)(D-C), 6 phép cӝng trӯ và 2 phép nhân vӟi 10n. Các phép toán này ÿӅu lҩy O(n) thӡi gian. Tӯ (III.3)
ta có phѭѫng trình ÿӋ quy:
T(1) = 1
T(n) = 3T(n/2) + cn
Giҧi phѭѫng trình ÿӋ quy này ta ÿѭӧc nghiӋm T(n) = O(nlog3) = O(n1.59). Giҧi thuұt này rõ ràng
ÿã ÿѭӧc cҧi thiӋn rҩt nhiӅu.
Giҧi thuұt thô ÿӇ nhân hai sӕ nguyên (dѭѫng hoһc âm) n chӳ sӕ là:
function Mult(x,y:integer; n:integer) : integer;
var
m1,m2,m3,A,B,C,D: integer;
s:integer;{Lѭu trӳ dҩu cӫa tích xy}
begin
s := sign(x)*sign(y);
{Hàm sign có giá trӏ 1 nӃu x dѭѫng và –1 nӃu x âm}
x := ABS(x);{Lҩy trӏ tuyӋt ÿӕi cӫa x}
y := ABS(y);
if n = 1 then mult:=x*y*s
else begin
A := left( x, n DIV 2);
B := right(x, n DIV 2);
C := left(y, n DIV 2);
D := right(y, n DIV 2);
m1 := mult(A,C, n DIV 2);
m2 := mult(A-B,D-C, n DIV 2);
m3 := mult(B,D, n DIV 2);
mult := (s * (m1 * 10n + (m1+m2+m3)* 10 n DIV 2 + m3));
end
end;
III.1.4- XӃp lӏch thi ÿҩu thӇ thao
Kӻ thuұt chia ÿӇ trӏ không nhӳng chӍ có ӭng dөng trong thiӃt kӃ giҧi thuұt mà còn trong nhiӅu
Oƭnh vӵc khác cӫa cuӝc sӕng. Chҷng hҥn xét viӋc xӃp lӏch thi ÿҩu thӇ thao theo thӇ thӭc ÿҩu vòng tròn 1
Oѭӧt cho n cҫu thӫ. Mӛi cҫu thӫ phҧi ÿҩu vӟi các cҫu thӫ khác, và mӛi cҫu thӫ chӍÿҩu nhiӅu nhҩt mӝt
trұn mӛi ngày. Yêu cҫu là xӃp mӝt lӏch thi ÿҩu sao cho sӕ ngày thi ÿҩu là ít nhҩt. Ta dӉ dàng thҩy rҵng
Wәng sӕ trұn ÿҩu cӫa toàn giҧi là n(n-1)/2. Nhѭ vұy nӃu n là mӝt sӕ chҹn thì ta có thӇ sҳp n/2 cһp thi ÿҩu
trong mӝt ngày và do ÿó cҫn ít nhҩt n-1 ngày. Ngѭӧc lҥi nӃu n là mӝt sӕ lҿ thì n-1 là mӝt sӕ chҹn nên ta
có thӇ sҳp (n-1)/2 cһp thi ÿҩu trong mӝt ngày và do ÿó ta cҫn n ngày. Giҧ sӱ n = 2k thì n là mӝt sӕ chҹnUpload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 39
và do ÿó cҫn tӕi thiӇu n-1 ngày.
Lӏch thi ÿҩu là mӝt bҧng n dòng và n-1 cӝt. Các dòng ÿѭӧc ÿánh sӕ tӯ 1 ÿӃn n và các cӝt ÿѭӧc
ÿánh sӕ tӯ 1 ÿӃn n-1, trong ÿó dòng i biӇu diӉn cho cҫu thӫ i, cӝt j biӇu diӉn cho ngày thi ÿҩu j và ô(i,j)
ghi cҫu thӫ phҧi thi ÿҩu vӟi cҫu thӫ i trong ngày j.
ChiӃn lѭӧc chia ÿӇ trӏ xây dӵng lӏch thi ÿҩu nhѭ sau: ĈӇ sҳp lӏch cho n cҫu thӫ, ta sӁ sҳp lӏch
cho n/2 cҫu thӫ, ÿӇ sҳp lӏch cho n/2 cҫu thӫ, ta sӁ sҳp lӏch cho n/4 cҫu thӫ... Quá trình này sӁ dүn ÿӃn
bài toán cѫ sӣ là sҳp lӏch thi ÿҩu cho 2 cҫu thӫ. Hai cҫu thӫ này sӁ thi ÿҩu mӝt trұn trong mӝt ngày, lӏch
thi ÿҩu cho hӑ thұt dӉ sҳp. Khó khăn chính là ӣ chӛ tӯ các lӏch thi ÿҩu cho hai cҫu thӫ, ta tәng hӧp lҥi
ÿӇÿѭӧc lӏch thi ÿҩu cӫa 4 cҫu thӫ, 8 cҩu thӫ, ...
Xuҩt phát tӯ lӏch thi ÿҩu cho hai cҫu thӫ ta có thӇ xây dӵng lӏch thi ÿҩu cho 4 cҫu thӫ nhѭ sau:
/ӏch thi ÿҩu cho 4 cҫu thӫ sӁ là mӝt bҧng 4 dòng, 3 cӝt. Lӏch thi ÿҩu cho 2 cҫu thӫ 1 và 2 trong ngày
thӭ 1 chính là lӏch thi ÿҩu cӫa hai cҫu thӫ (bài toán cѫ sӣ). Nhѭ vұy ta có Ô(1,1) = “2” và Ô(2,1) = “1”.
7ѭѫng tӵ ta có lӏch thi ÿҩu cho 2 cҫu thӫ 3 và 4 trong ngày thӭ 1. Nghƭa là Ô(3,1) =”4” và Ô(4,1) =
“3”. (Ta cӕ thӇ thҩy rҵng Ô(3,1) = Ô(1,1) + 2 và Ô(4,1) = Ô(2,1) + 2 ). Bây giӡÿӇ hoàn thành lӏch thi
ÿҩu cho 4 cҫu thӫ, ta lҩy góc trên bên trái cӫa bҧng lҳp vào cho góc dѭӟi bên phҧi và lҩy góc dѭӟi bên
trái lҳp cho góc trên bên phҧi.
Lӏch thi ÿҩu cho 8 cҫu thӫ là mӝt bҧng gӗm 8 dòng, 7 cӝt. Góc trên bên trái chính là lӏch thi ÿҩu
trong 3 ngày ÿҫu cӫa 4 cҫu thӫ tӯ 1 ÿӃn 4. Các ô cӫa góc dѭӟi bên trái sӁ bҵng các ô tѭѫng ӭng cӫa góc
trên bên trái cӝng vӟi 4. Ĉây chính là lӏch thi ÿҩu cho 4 cҫu thӫ 5, 6, 7 và 8 trong 3 ngày ÿҫu. Bây giӡ
chúng ta hoàn thành viӋc sҳp lӏch bҵng cách lҩp ÿҫy góc dѭӟi bên phҧi bӣi góc trên bên trái và góc trên
bên phҧi bӣi góc dѭӟi bên trái.
III.1.5- Bài toán con cân bҵng (Balancing Subproblems)
Ĉӕi vӟi kӻ thuұt chia ÿӇ trӏ, nói chung sӁ tӕt hѫn nӃu ta chia bài toán cҫn giҧi thành các bài toán
con có kích thѭӟc gҫn bҵng nhau. Ví dө, sҳp xӃp trӝn (MergeSort) phân chia bài toán thành hai bài
toán con có cùng kích thѭӟc n/2 và do ÿó thӡi gian cӫa nó chӍ là O(nlogn). Ngѭӧc lҥi trong trѭӡng hӧp
[ҩu nhҩt cӫa QuickSort, khi mҧng bӏ phân hoҥch lӋch thì thӡi gian thӵc hiӋn là O(n2).
Nguyên tҳc chung là chúng ta tìm cách chia bài toán thành các bài toán con có kích thѭӟc xҩp xӍ bҵng
nhau thì hiӋu suҩt sӁ cao hѫn.
III.2- QUY HOҤCH ĈӜNG
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 40
III.2.1- Nӝi dung kӻ thuұt
III.2.2- Bài toán tính sӕ tә hӧp
III.2.1- Nӝi dung kӻ thuұt
Nhѭ trong III.1 chúng ta ÿã nói, kӻ thuұt chia ÿӇ trӏ thѭӡng dүn chúng ta tӟi mӝt giҧi thuұt ÿӋ
quy. Trong các giҧi thuұt ÿó, có thӇ có mӝt sӕ giҧi thuұt thӡi gian mNJ. Tuy nhiên, thѭӡng chӍ có mӝt sӕ
ÿa thӭc các bài toán con, ÿLӅu ÿó có nghƭa là chúïng ta ÿã phҧi giҧi mӝt sӕ bài toán con nào ÿó trong
nhiӅu lҫn. ĈӇ tránh viӋc giҧi dѭ thӯa mӝt sӕ bài toán con, chúng ta tҥo ra mӝt bҧng lѭu tҩt cҧ kӃt quҧ
Fӫa các bài toán con và khi cҫn chúng ta chӍ cҫn tham khҧo tӟi kӃt quҧÿã ÿѭӧc lѭu trong bҧng mà
không cҫn phҧi giҧi lҥi bài toánÿó. Lҩp ÿҫy bҧng kӃt quҧ các bài toán con theo mӝt quy luұt nào ÿó
ÿӇ nhұn ÿѭӧc kӃt quҧ cӫa bài toán ban ÿҫu (cNJng ÿã ÿѭӧc lѭu trong mӝt ô nào ÿó cӫa bҧng) ÿѭӧc gӑi là
quy hoҥch ÿӝng.
III.2.2- Bài toán tính sӕ tә hӧp
Mӝt bài toán khá quen thuӝc vӟi chúng ta là tính sӕ tә hӧp chұp k cӫa n theo công thӭc:
Ckn = 1 nӃu k=0 hoһc k = n
Ckn = Ck-1n-1 + Ckn-1 nӃu 0 < k < n
Công thӭc trên ÿã gӧi ý cho chúng ta mӝt giҧi thuұt ÿӋ quy nhѭ sau:
function Comb(n,k : integer) : Integer;
begin
if (k=0) or (k=n) then Comb := 1
else Comb := Comb(n-1, k-1) + Comb(n-1,k);
end;
Gӑi T(n) là thӡi gian ÿӇ tính sӕ tә hӧp chұp k cӫa n, thì ta có phѭѫng trình ÿӋ quy:
T(1) = C1
T(n) = 2T(n-1) + C2
Giҧi phѭѫng trình này ta ÿѭӧc T(n) = O(2n), nhѭ vұy là mӝt giҧi thuұt thӡi gian mNJ, trong khi
chӍ có mӝt ÿa thӭc các bài toán con. ĈLӅu ÿó chӭng tӓ rҵng có nhӳng bài toán con ÿѭӧc giҧi nhiӅu lҫn.
Chҷng hҥn ÿӇ tính Comb(4,2) ta phҧi tính Comb(3,1) và Comb(3,2). ĈӇ tính Comb(3,1) ta phҧi
tính Comb(2,0) và Comb(2,1). ĈӇ tính Comb(3,2) ta phҧi tính Comb(2,1) và Comb(2,2). Nhѭ vұy ÿӇ
tính Comb(4,2) ta phҧi tính Comb(2,1) hai lҫn. Hình 3-2 sau minh hoҥ rõ ÿLӅu ÿó.
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 41
Áp dөng kӻ thuұt quy hoҥch ÿӝng ÿӇ khҳc phөc tình trҥng trên, ta xây dӵng mӝt bҧng gӗm n+1
dòng (tӯ 0 ÿӃn n) và n+1 cӝt (tӯ 0 ÿӃn n) và ÿLӅn giá trӏ cho O(i,j) theo quy tҳc sau: (Quy tҳc tam giác
Pascal):
O(0,0) = 1;
O(i,0) =1;
O(i,i) = 1 vӟi 0 < i ( n;
O(i,j) = O(i-1,j-1) + O(i-1,j) vӟi 0 < j < i £ n.
Chҷng hҥn vӟi n = 4 ta có bҧng bên.
O(n,k) chính là Comb(n,k) và ta có giҧi thuұt nhѭ sau:
function Comb(n, k : Integer) : Integer
var C: array[0..n, 0..n] of integer;
i,j : integer;
begin
{1} C[0,0] := 1;
{2} for i := 1 to n do begin
{3} C[i,0] := 1;
{4} C[i,i] := 1;
{5} for j := 1 to i-1 do C[i,j] := C[i-1,j-1] + C[i-1,j];
end;
{6} Comb := C[n,k];
end;
Vòng lһp {5} thӵc hiӋn i-1 lҫn, mӛi lҫn O(1). Vòng lһp {2} có i chҥy tӯ 1 ÿӃn n, nên nӃu gӑi
T(n) là thӡi gian thӵc hiӋn giҧi thuұt thì ta có:
III.3- KӺ THUҰT "THAM ĂN"
III.3.1- Bài toán tӕi ѭu tә hӧp
III.3.2- Nӝi dung kӻ thuұt tham ăn
III.3.3- Bài toán ÿѭӡng ÿi cӫa ngѭӡi giao hàng
III.3.4- Bài toán cái ba lô Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 42
III.3.1- Bài toán tӕi ѭu tә hӧp
Là mӝt dҥng cӫa bài toán tӕi ѭu, nó có dҥng tәng quát nhѭ sau:
· Cho phiӃm hàm xác ÿӏnh trên mӝt tұp hӳu hҥn các phҫn tӱ D. Hàm
f(X) ÿѭӧc gӑi là hàm mөc tiêu.
· Mӛi phҫn tӱ X D có dҥng X= (x1, x2, .. xn) ÿѭӧc gӑi là mӝt phѭѫng án.
· Cҫn tìm mӝt phѭѫng án X D sao cho hàm f(X) ÿҥt min (max). Phѭѫng án X nhѭ thӃÿѭӧc
Jӑi là phѭѫng án tӕi ѭu.
Ta có thӇ tìm thҩy phѭѫng án tӕi ѭu bҵng phѭѫng pháp “vét cҥn” nghƭa là xét tҩt cҧ các
phѭѫng án trong tұp D (hӳu hҥn) ÿӇ xác ÿinh phѭѫng án tӕt nhҩt. Mһc dù tұp hӧp D là hӳu hҥn nhѭng
ÿӇ tìm phѭѫng án tӕi ѭu cho mӝt bài toán kích thѭӟc n bҵng phѭѫng pháp “vét cҥn” ta có thӇ cҫn mӝt
thӡi gian mNJ.
Các phҫn tiӃp theo cӫa chѭѫng này sӁ trình bày mӝt sӕ kӻ thuұt giҧi bài toán tӕi ѭu tә hӧp mà
thӡi gian có thӇ chҩp nhұn ÿѭӧc.
III.3.2- Nӝi dung kӻ thuұt tham ăn
Kӻ thuұt tham ăn thѭӡng ÿѭӧc vұn dөng ÿӇ giҧi bài toán tӕi ѭu tә hӧp bҵng cách xây dӵng mӝt
phѭѫng án X. Phѭѫng án X ÿѭӧc xây dӵng bҵng cách lӵa chӑn tӯng thành phҫn xi cӫa X cho ÿӃn khi
hoàn chӍnh (ÿӫ n thành phҫn). Vӟi mӛi xi , ta sӁ chӑn xi tӕi ѭu. Vӟi cách này thì có thӇӣ bѭӟc cuӕi
cùng ta không còn gì ÿӇ chӑn mà phҧi chҩp nhұn mӝt giá trӏ cuӕi cùng còn lҥi.
Áp dөng kӻ thuұt tham ăn sӁ cho mӝt giҧi thuұt thӡi gian ÿa thӭc, tuy nhiên nói chung chúng
ta chӍÿҥt ÿѭӧc mӝt phѭѫng án tӕt chӭ không phҧi là tӕi ѭu.
Có rҩt nhiӅu bài toán mà ta có thӇ giҧi bҵng kӻ thuұt này, sau ÿây là mӝt sӕ ví dө.
III.3.3- Bài toán ÿѭӡng ÿi cӫa ngѭӡi giao hàng
Chúng ta sӁ xét mӝt bài toán rҩt nәi tiӃng có tên là bài toán tìm ÿѭӡng ÿi cӫa ngѭӡi giao
hàng (TSP - Traveling Salesman Problem): Có mӝt ngѭӡi giao hàng cҫn ÿi giao hàng tҥi n thành phӕ.
Xuҩt phát tӯ mӝt thành phӕ nào ÿó, ÿi qua các thành phӕ khác ÿӇ giao hàng và trӣ vӅ thành phӕ ban
ÿҫu. Mӛi thành phӕ chӍÿӃn mӝt lҫn, khoҧng cách tӯ mӝt thành phӕÿӃn các thành phӕ khác là xác ÿӏnh
ÿѭӧc. Khoҧng cách giӳa hai thành phӕ có thӇ là khoҧng cách ÿӏa lý, có thӇ là cѭӟc phí di chuyӇn hoһc
thӡi gian di chuyӇn. Ta gӑi chung là ÿӝ dài. Hãy tìm mӝt chu trình (mӝt ÿѭӡng ÿi khép kín thӓa mãn
ÿLӅu kiӋn trên) sao cho tәng ÿӝ dài các cҥnh là nhӓ nhҩt. Hay còn nói là tìm mӝt phѭѫng án có giá nhӓ
nhҩt. Bài toán này cNJng ÿѭӧc gӑi là bài toán ngѭӡi du lӏch.
Vӟi phѭѫng pháp vét cҥn ta xét tҩt cҧ các chu trình, mӛi chu trình tính tәng ÿӝ dài các cҥnh
Fӫa nó rӗi chӑn mӝt chu trình có tәng ÿӝ dài nhӓ nhҩt. Tuy nhiên chúng ta cҫn xét tҩt cҧ là chu
trình. Thӵc vұy, do mӛi chu trình ÿӅu ÿi qua tҩt cҧ các ÿӍnh (thành phӕ) nên ta có thӇ cӕÿӏnh mӝt ÿӍnh.
7ӯÿӍnh này ta có n-1 cҥnh tӟi n-1 ÿӍnh khác, nên ta có n-1 cách chӑn cҥnh ÿҫu tiên cӫa chu trình. Sau
khi ÿã chӑn ÿѭӧc cҥnh ÿҫu tiên, chúng ta còn n-2 cách chӑn cҥnh thӭ hai, do ÿó ta có (n-1)(n-2) cách
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 43
chӑn hai cҥnh. Cӭ lý luұn nhѭ vұy ta sӁ thҩy có (n-1)! cách chӑn mӝt chu trình. Tuy nhiên vӟi mӛi chu
trình ta chӍ quan tâm ÿӃn tәng ÿӝ dài các cҥnh chӭ không quan tâm ÿӃn hѭӟïng ÿi theo chiӅu dѭѫng
hay âm vì vұy có tҩt cҧ phѭѫng án. Ĉó là mӝt giҧi thuұt thӡi gian mNJ !!!.
.ӻ thuұt tham ăn áp dөng vào ÿây là:
1. Tính ÿӝ dài cӫa tҩt cҧ các cҥnh (có tҩt cҧ Fҥnh).
2. Xét các cҥnh có ÿӝ dài tӯ nhӓÿӃn lӟn ÿӇÿѭa vào chu trình.
3. Mӝt cҥnh sӁÿѭӧc ÿѭa vào chu trình nӃu cҥnh ÿó thӓa mãn hai ÿLӅu kiӋn sau:
· Không tҥo thành mӝt chu trình thiӃu (không ÿi qua ÿӫ n ÿӍnh)
· Không tҥo thành mӝt ÿӍnh có cҩp 3 (tӭc là không ÿѭӧc có nhiӅu hѫn hai cҥnh xuҩt phát
Wӯ mӝt ÿӍnh, do yêu cҫu cӫa bài toán là mӛi thành phӕ chӍÿѭӧc ÿӃn mӝt lҫn: mӝt lҫn ÿӃn và mӝt lҫn ÿi)
4. Lһp lҥi bѭӟc 3 cho ÿӃn khi xây dӵng ÿѭӧc mӝt chu trình.
Vӟi kӻ thuұt này ta chӍ cҫn n(n-1)/2 phép chӑn nên ta có mӝt giҧi thuұt cҫn O(n2) thӡi gian.
Ví dө 3-1: Cho bài toán TSP vӟi 6 ÿӍnh ÿѭӧc cho bӣi các tӑa ÿӝ nhѭ sau:
Do có 6 ÿӍnh nên có tҩt cҧ 15 cҥnh. Ĉó là các cҥnh: ab, ac, ad, ae, af, bc, bd, be, bf, cd, ce, cf,
de, df và ef. Ĉӝ dài các cҥnh ӣÿây là khoҧng cách Euclide. Trong 15 cҥnh này thì de = 3 là nhӓ nhҩt,
nên de ÿѭӧc chӑn vào chu trình. KӃÿӃn là 3 cҥnh ab, bc và ef ÿӅu có ÿӝ dài là 5. Cҧ 3 cҥnh ÿӅu thӓa
mãn hai ÿLӅu kiӋn nói trên, nên ÿӅu ÿѭӧc chӑn vào chu trình. Cҥnh có ÿӝ dài nhӓ kӃ tiӃp là ac = 7.08,
nhѭng không thӇÿѭa cҥnh này vào chu trình vì nó sӁ tҥo ra chu trình thiӃu (a-b-c-a). Cҥnh df cNJng bӏ
loҥi vì lý do tѭѫng tӵ. Cҥûnh be ÿѭӧc xem xét nhѭng rӗi cNJng bӏ loҥi do tҥo ra ÿӍnh b và ÿӍnh e có cҩp
3. Tѭѫng tӵ chúng ta cNJng loҥi bd. cd là cҥnh tiӃp theo ÿѭӧc xét và ÿѭӧc chӑn. Cuӕi cùng ta có chu
trình a-b-c-d-e-f-a vӟi tәng ÿӝ dài là 50.
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 44
Ĉây chӍ là mӝt phѭѫng án tӕt.
Phѭѫng án tӕi ѭu là chu trình a-c-d-e-f-b-a vӟi tәng ÿӝ dài là 48.39.
Giҧi thuұt sѫ bӝ nhѭ sau:
procedure TSP;
begin
{E là tұp các cҥnh }
{Sҳp xӃp các cҥnh trong E theo thӭ tӵ tăng cӫa ÿӝ dài }
Chu_Trinh := F;
Gia := 0.0;
while E F do begin
if cҥnh e có thӇ chӑn then begin
Chu_Trinh := Chu_Trinh + e ;
Gia := Gia + ÿӝ dài cӫa e;
end;
E := E-e;
end ;
end;
Mӝt cách tiӃp cұn khác cӫa kӻ thuұt tham ăn vào bài toán này là:
1. Xuҩt phát tӯ mӝt ÿӍnh bҩt kǤ, chӑn mӝt cҥnh có ÿӝ dài nhӓ nhҩt trong tҩt cҧ các cҥnh ÿi ra tӯ
ÿӍnh ÿó ÿӇÿӃn ÿӍnh kӃ tiӃp.
2. TӯÿӍnh kӃ tiӃp ta lҥi chӑn mӝt cҥnh có ÿӝ dài nhӓ nhҩt ÿi ra tӯÿӍnh này thoҧ mãn hai ÿLӅu
kiӋn nói trên ÿӇÿi ÿӃn dӍnh kӃ tiӃp.
3. Lһp lҥi bѭӟc 2 cho ÿӃn khi ÿi tӟi ÿӍnh n thì quay trӣ vӅÿӍnh xuҩt phát.
III.3.4- Bài toán cái ba lô
Cho mӝt cái ba lô có thӇÿӵng mӝt trӑng lѭӧng W và n loҥi ÿӗ vұt, mӛi ÿӗ vұt
i có mӝt trӑng lѭӧng gi và mӝt giá trӏ vi. Tҩt cҧ các loҥi ÿӗ vұt ÿӅu có sӕ lѭӧng không hҥn chӃ. Tìm
Pӝt cách lӵa chӑn các ÿӗ vұt ÿӵng vào ba lô, chӑn các loҥi ÿӗ vұt nào, mӛi loҥi lҩy bao nhiêu sao cho
Wәng trӑng lѭӧng không vѭӧt quá W và tәng giá trӏ là lӟn nhҩt.
Theo yêu cҫu cӫa bài toán thì ta cҫn nhӳng ÿӗ vұt có giá trӏ cao mà trӑng lѭӧng lҥi nhӓÿӇ sao
cho có thӇ mang ÿѭӧc nhiӅu “ÿӗ quý”, sӁ là hӧp lý khi ta quan tâm ÿӃn yӃu tӕ “ÿѫn giá” cӫa tӯng loҥi
ÿӗ vұt tӭc là tӹ lӋ giá trӏ/trӑng lѭӧng. Ĉѫn giá càng cao thì ÿӗ càng quý. Tӯÿó ta có kӻ thuұt greedy ápUpload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 45
Gөng cho bài toán này là:
1. Tính ÿѫn giá cho các loҥi ÿӗ vұt.
2. Xét các loҥi ÿӗ vұt theo thӭ tӵÿѫn giá tӯ lӟn ÿӃn nhӓ.
3. Vӟi mӛi ÿӗ vұt ÿѭӧc xét sӁ lҩy mӝt sӕ lѭӧng tӕi ÿa mà trӑng lѭӧng còn lҥi cӫa ba lô cho
phép.
4. Xác ÿӏnh trӑng luӧng còn lҥi cӫa ba lô và quay lҥi bѭӟc 3 cho ÿӃn khi không còn có thӇ
chӑn ÿѭӧc ÿӗ vұt nào nӳa.
Ví dө 3-2: Ta có mӝt ba lô có trӑng lѭӧng làì 37 và 4 loҥi ÿӗ vұt vӟi trӑng lѭӧng và giá trӏ
Wѭѫng ӭng ÿѭӧc cho trong bҧng (hình 3-6)
Tӯ bҧng ÿã cho ta tính ÿѫn giá cho các loҥi ÿӗ vұt và sҳp xӃp các loҥi ÿӗ vұt này theo thӭ tӵ
ÿѫn giá giҧm dҫn ta có bҧng (hình 3-7).
Theo ÿó thì thӭ tӵѭu tiên ÿӇ chӑn ÿӗ vұt là là B, A, D và cuӕi cùng là C.
Vұt B ÿѭӧc xét ÿҫu tiên và ta chӑn tӕi ÿa 3 cái vì mӛi cái vì trӑng lѭӧng mӛi cái là 10 và ba lô
có trӑng lѭӧng 37. Sau khi ÿã chӑn 3 vât loҥi B, trӑng lѭӧng còn lҥi trong ba lô là 37 - 3*10 = 7. Ta xét
ÿӃn vұt A, vì A có trӑng lѭӧng 15 mà trӑng lѭӧng còn lҥi cӫa balô chӍ còn 7 nên không thӇ chӑn vұt A.
Xét vұt D và ta thҩy có thӇ chӑn 1 vұt D, khi ÿó trӑng lѭӧng còn lҥi cӫa ba lô là 7-4 = 3. Cuӕi cùng ta
chӑn ÿѭӧc mӝt vұt C.
Nhѭ vұy chúng ta ÿã chӑn 3 cái loҥi B, mӝt cái loҥi D và 1 cái loҥi C. Tәng trӑng lѭѫng là
3*10 + 1*4 + 1*2 = 36 và tәng giá trӏ là 3*25+1*6+1*2 = 83.
Chú ý có mӝt sӕ biӃn thӇ cӫa bài toán cái ba lô nhѭ sau:
1. Mӛi ÿӗ vұt i chӍ có mӝt sӕ lѭӧng si. Vӟi bài toán này khi lӵa chӑn vұt i ta không ÿѭӧc lҩy
Pӝt sӕ lѭӧng vѭӧt quá si.
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 46
2. Mӛi ÿӗ vұt chӍ có mӝt cái. Vӟi bài toán này thì vӟi mӛi ÿӗ vұt ta chӍ có thӇ chӑn hoһc
không chӑn.
III.4- KӺ THUҰT QUAY LUI
III.4.1- Ĉӏnh trӏ cây biӇu thӭc sӕ hӑc
III.4.2- Kӻ thuұt cҳt tӍa Alpha-Beta
III.4.3- Kӻ thuұt nhánh cұn
Kӻ thuұt quay lui (backtracking) nhѭ tên gӑi cӫa nó, là mӝt quá trình phân tích ÿi xuӕng. Tҥi
Pӛi bѭӟc phân tích chúng ta chѭa giҧi quyӃt ÿѭӧc vҩn ÿӅ do còn thiӃu cӭ liӋu nên cӭ phҧi phân tích
cho tӟi các ÿLӇm dӯng, nѫi chúng ta xác ÿӏnh ÿѭӧc lӡi giҧi cӫa chúng hoһc là xác ÿӏnh ÿѭӧc là không
thӇ (hoһc không nên) tiӃp tөc theo hѭӟng này. Tӯ các ÿLӇm dӯng này chúng ta quay ngѭӧc trӣ lҥi theo
con ÿѭӡng mà chúng ta ÿã ÿi qua ÿӇ giҧi quyӃt các vҩn ÿӅ còn tӗn ÿӑng và cuӕi cùng ta sӁ giҧi quyӃt
ÿѭӧc vҩn ÿӅ ban ÿҫu.
Ӣÿây chúng ta sӁ xét 3 kӻ thuұt quay lui: “vét cҥn” là kӻ thuұt phҧi ÿi tӟi tҩt cҧ các ÿLӇm dӯng
Uӗi mӟi quay lui. “Cҳt tӍa Alpha-Beta” và “Nhánh-Cұn” là hai kӻ thuұt cho phép chúng ta không cҫn
thiӃt phҧi ÿi tӟi tҩt cҧ các ÿLӇm dӯng, mà chӍ cҫn ÿi ÿӃn mӝt sӕÿLӇm nào ÿó và dӵa vào mӝt sӕ suy
luұn ÿӇ có thӇ quay lui sӟm. Các kӻ thuұt này sӁÿѭӧc trình bày thông qua mӝt sӕ bài toán cө thӇ sau.
III.4.1- Ĉӏnh trӏ cây biӇu thӭc sӕ hӑc
Trong các ngôn ngӳ lұp trình ÿӅu có các biӇu thӭc sӕ hӑc, viӋc dӏch các biӇu thӭc này ÿòi hӓi
phҧi ÿánh giá (ÿӏnh trӏ) chúng. ĈӇ làm ÿѭӧc ÿLӅu ÿó cҫn phҧi có mӝt biӇu diӉn trung gian cho biӇu
thӭc. Mӝt trong các biӇu diӉn trung gian cho biӇu thӭc là cây biӇu thӭc.
Cây biӇu thӭc sӕ hӑc là mӝt cây nhӏ phân, trong ÿó các nút lá biӇu diӉn cho các toán hҥng, các
nút trong biӇu diӉn cho các toán tӱ.
Ví dө 3-3: BiӇu thӭc 5 + 2 * 3 - 4 sӁÿѭӧc biӇu diӉn bӣi cây trong hình 3-8:
Trӏ cӫa mӝt nút lá chính là trӏ cӫa toán hҥng mà nút ÿó biӇu diӉn. Trӏ cӫa mӝt nút trong có
ÿѭӧc bҵng cách lҩy toán tӱ mà nút ÿó biӇu diӉn áp dөng vào các con cӫa nó.
Trӏ cӫa nút gӕc chính là trӏ cӫa biӇu thӭc.
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 47
Nhѭ vұy ÿӇÿӏnh trӏ cho nút gӕc, chúng ta phҧi ÿӏnh trӏ cho hai con cӫa nó, ÿӕi vӟi mӛi con ta
xem nó có phҧi là nút lá hay không, nӃu không phҧi ta lҥi phҧi xét hai con cӫa nút ÿó. Quá trình cӭ tiӃp
Wөc nhѭ vұy cho tӟi khi gһp các nút lá mà giá trӏ cӫa chúng ÿã ÿѭӧc biӃt, quay lui ÿӇÿӏnh trӏ cho các
nút cha cӫa các nút lá và cӭ nhѭ thӃ mà ÿӏnh trӏ cho tә tiên cӫa chúng. Ĉó chính là kӻ thuұt quay lui vét
Fҥn, vì chúng ta phҧi lҫn ÿӃn tҩt cҧ các nút lá mӟi ÿӏnh trӏÿѭӧc cho các nút trong và do thӃ mӟi ÿӏnh trӏ
ÿѭӧc cho nút gӕc.
Ví dө 3-4: Vӟi cây biӇu thӭc trong ví dө 3-3. ĈӇÿӏnh trӏ cho nút - chúng ta phҧi ÿӏnh trӏ cho
nút + và nút 4. Nút 4 là nút lá nên giá trӏ cӫa nó là 4. ĈӇÿӏnh trӏ cho nút + ta phҧi ÿӏnh trӏ cho nút 5 và
nút *. Nút 5 là nút lá nên giá trӏ cӫa nó là 5. ĈӇÿӏnh trӏ cho nút *, ta phҧi ÿӏnh trӏ cho nút 2 và nút 3. Cҧ
hai nút này ÿӅu là lá nên giá trӏ cӫa chúng tѭѫng ӭng là 2 và 3. Quay lui lҥi nút *, lҩy toán tӱ * áp dөng
cho hai con cӫa nó là 2 và 3 ta ÿѭӧc trӏ cӫa nút * là 6. Quay lui vӅ nút +, lҥi áp dөng toán tӱ + vào hai
con cӫa nó là 5 và 6 ÿѭӧc trӏ cӫa nút + là 11. Cuӕi cùng quay vӅ nút -, áp dөng toán tӱ - vào hai con
Fӫa nó là 11 và 4 ta ÿѭӧc trӏ cӫa nút - (nút gӕc) là 7. Ĉó chính là trӏ cӫa biӇu
thӭc. Trong hình 3-9, mNJi tên nét ÿӭt minh hӑa quá trình ÿi tìm nút lá và mNJi
tên nét liӅn minh hӑa quá trình quay lui ÿӇÿӏnh trӏ cho các nút, các sӕ bên phҧi
Pӛi nút là trӏ cӫa nút ÿó.
Giҧi thuұt sѫ bӝÿӇÿӏnh trӏ mӝt nút bҩt kǤ nhѭ sau:
function Eval(n : node): real;
begin
if n là lá then return (trӏ cӫa toán hҥng trong n)
else return (Toán tӱ trong n (Eval (Con trái cӫa n), Eval (Con phҧi cӫa n)) );
end;
Muӕn ÿӏnh trӏ cho cây biӇu thӭc T, ta gӑi Eval(ROOT(T)).
III.4.2- Kӻ thuұt cҳt tӍa Alpha-Beta
Cây trò chѫi
Xét mӝt trò chѫi trong ÿó hai ngѭӡi thay phiên nhau ÿi nѭӟc cӫa mình nhѭ
Fӡ vua, cӡ tѭӟng, carô,... Trò chѫi có mӝt trҥng thái bҳt ÿҫu và mӛi nѭӟc ÿi sӁ biӃn ÿәi trҥng thái hiӋn
hành thành mӝt trҥng thái mӟi. Trò chѫi sӁ kӃt thúc theo mӝt quy ÿӏnh nào ÿó, theo ÿó thì cuӝc chѫi sӁUpload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 48
Gүn ÿӃn mӝt trҥng thái phҧn ánh có mӝt ngѭӡi thҳng cuӝc hoһc mӝt trҥng thái mà cҧ hai ÿҩu thӫ không
thӇ phát triӇn ÿѭӧc nѭӟc ÿi cӫa mình, ta gӑi nó là trҥng thái hòa cӡ. Ta tìm cách phân tích xem tӯ mӝt
trҥng thái nào ÿó sӁ dүn ÿӃn ÿҩu thӫ nào sӁ thҳng vӟi ÿLӅu kiӋn cҧ hai ÿҩu thӫÿӅu có trình ÿӝ nhѭ
nhau.
Mӝt trò chѫi nhѭ vұy có thӇÿѭӧc biӇu diӉn bӣi mӝt cây, gӑi là cây trò chѫi. Mӛi mӝt nút cӫa
cây biӇu diӉn cho mӝt trҥng thái. Nút gӕc biӇu diӉn cho trҥng thái bҳt ÿҫu cӫa cuӝc chѫi. Mӛi nút lá
biӇu diӉn cho mӝt trҥng thái kӃt thúc cӫa trò chѫi (trҥng thái thҳng thua hoһc hòa). NӃu trҥng thái x
ÿѭӧc biӇu diӉn bӣi nút n thì các con cӫa n biӇu diӉn cho tҩt cҧ các trҥng thái kӃt quҧ cӫa các nѭӟc ÿi có
thӇ xuҩt phát tӯ trҥng thái x.
Ví dө 3-5: Xét trò chѫi carô có 9 ô. Hai ngѭӡi thay phiên nhau ÿi X hoһc O. Ngѭӡi nào ÿi
ÿѭӧc 3 ô thҷng hàng (ngang, dӑc, xiên) thì thҳng cuӝc. NӃu ÿã hӃt ô ÿi mà chѭa phân thҳng bҥi thì hai
ÿҩu thӫ hòa nhau. Mӝt phҫn cӫa trò chѫi này ÿѭӧc biӇu diӉn bӣi cây sau:
Trong cây trò chѫi trên, các nút lá ÿѭӧc tô nӅn và viӅn khung ÿôi ÿӇ dӉ phân biӋt vӟi các nút
khác. Ta có thӇ gán cho mӛi nút lá mӝt giá trӏÿӇ phҧn ánh trҥng thái thҳng thua hay hòa cӫa các ÿҩu
thӫ. Chҷng hҥn ta gán cho nút lá các giá trӏ nhѭ sau:
· 1 nӃu tҥi ÿó ngѭӡi ÿi X ÿã thҳng,
· -1 nӃu tҥi ÿó ngѭӡi ÿi X ÿã thua và Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 49
· 0 nӃu hai ÿҩu thӫÿã hòa nhau.
Nhѭ vұy tӯ mӝt trҥng thái bҩt kǤ, ÿӃn lѭӧt mình, ngѭӡi ÿi X sӁ chӑn cho mình mӝt nѭӟc ÿi sao
cho dүn ÿӃn trҥng thái có giá trӏ lӟn nhҩt (trong trѭӡng hӧp này là 1). Ta nói X chӑn nѭӟc ÿi MAX, nút
mà tӯÿó X chӑn nѭӟc ÿi cӫa mình ÿѭӧc gӑi là nút MAX. Ngѭӡi ÿi O ÿӃn lѭӧt mình sӁ chӑn mӝt nѭӟc
ÿi sao cho dүn ÿӃn trҥng thái có giá trӏ nhӓ nhҩt (trong trѭӡng hӧp này là -1, khi ÿó X sӁ thua và do ÿó
O sӁ thҳng). Ta nói O chӑn nѭӟc ÿi MIN, nút mà tӯÿó O chӑn nѭӟc ÿi cӫa mình ÿѭӧc gӑi là nút MIN.
Do hai ÿҩu thӫ luân phiên nhau ÿi nѭӟc cӫa mình nên các mӭc trên cây trò chѫi cNJng luân phiên nhau
là MAX và MIN. Cây trò chѫi vì thӃ còn có tên là cây MIN-MAX. Ta có thӇÿѭa ra mӝt quy tҳc ÿӏnh
trӏ cho các nút trên cây ÿӇ phҧn ánh tình trҥng thҳng thua hay hòa và khҧ năng thҳng cuӝc cӫa hai ÿҩu
thӫ.
NӃu mӝt nút là nút lá thì trӏ cӫa nó là giá trӏÿã ÿѭӧc gán cho nút ÿó. Ngѭӧc lҥi, nӃu nút là nút
MAX thì trӏ cӫa nó bҵng giá trӏ lӟn nhҩt cӫa tҩt cҧ các trӏ cӫa các con cӫa nó. NӃu nút là nút MIN thì trӏ
Fӫa nó là giá trӏ nhӓ nhҩt cӫa tҩt cҧ các trӏ cӫa các con cӫa nó.
Quy tҳc ÿӏnh trӏ này cNJng gҫn giӕng vӟi quy tҳc ÿӏnh trӏ cho cây biӇu thӭc sӕ hӑc, ÿLӇm khác
biӋt ӣÿây là các toán tӱ là các hàm lҩy max hoһc min và mӛi nút có thӇ có nhiӅu con. Do vұy ta có thӇ
dùng kӻ thuұt quay lui ÿӇÿӏnh trӏ cho các nút cӫa cây trò chѫi.
ĈӇ cài ÿһt ta có mӝt sӕ giҧ thiӃt sau:
· Ta có mӝt hàm Payoff nhұn vào mӝt nút lá và cho ta giá trӏ cӫa nút lá ÿó.
· Các hҵng và - tѭѫng ӭng là các trӏ Payoff lӟn nhҩt và nhӓ nhҩt.
· Khai báo kiӇu ModeType = (MIN, MAX) ÿӇ xác ÿӏnh ÿӏnh trӏ cho nút là MIN hay MAX.
· Mӝt kiӇu NodeType ÿѭӧc khai báo mӝt cách thích hӧp ÿӇ biӇu diӉn cho mӝt nút trên cây
phҧn ánh mӝt trҥng thái cӫa cuӝc chѫi.
· Ta có mӝt hàm is_leaf ÿӇ xác ÿӏnh xem mӝt nút có phҧi là nút lá hay không?
· Hàm max và min tѭѫng ӭng lҩy giá trӏ lӟn nhҩt và giá trӏ nhӓ nhҩt cӫa hai giá trӏ.
Giҧi thuұt vét cҥn ÿӏnh trӏ cây trò chѫi
Hàm Search nhұn vào mӝt nút n và kiӇu mode cӫa nút ÿó (MIN hay MAX) trҧ vӅ giá trӏ cӫa
nút.
NӃu nút n là nút lá thì trҧ vӅ giá trӏÿã ÿѭӧc gán cho nút lá. Ngѭӧc lҥi ta cho n mӝt giá trӏ tҥm
value là - hoһc tùy thuӝc n là nút MAX hay MIN và xét con cӫa n. Sau khi mӝt con cӫa n có giá trӏ
V thì ÿһt lҥi value = max(value,V) nӃu n là nút MAX và value = min(value,V) nӃu n là nút MIN. Khi
Wҩt cҧ các con cӫa n ÿã ÿѭӧc xét thì giá trӏ tҥm value cӫa n trӣ thành giá trӏ cӫa nó.
function Search(n : NodeType; mode: ModeType): real;
var C : NodeType ; { C là mӝt nút con cӫa nút n}
Value : real;
{Lúc ÿҫu ta cho value mӝt giá trӏ tҥm, sau khi ÿã xét hӃt tҩt cҧ các con cӫa nút n thì value là giáUpload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 50
trӏ cӫa nút n }
begin
if is_leaf(n) then return ( Payoff(n) )
else begin
{Khӣi tҥo giá trӏ tҥm cho n }
if mode = MAX then value := - else value := ;
{Xét tҩt cҧ các con cӫa n, mӛi lҫn xác ÿӏnh ÿѭӧc giá trӏ cӫa mӝt nút con, ta phҧi ÿһt lҥi giá trӏ
Wҥm value. Khi ÿã xét hӃt tҩt cҧ các con thì value là giá trӏ cӫa n}
for vӟi mӛi con C cӫa n do
if mode = MAX then
Value := max(Value, Search(C, MIN) )
else Value := min(Value, Search(C, MAX) );
return (value);
end;
end;
.ӻ thuұt cҳt tӍa Alpha-Beta (Alpha-Beta Pruning)
Trong giҧi thuұt vét cҥn ӣ trên, ta thҩy ÿӇÿӏnh trӏ cho mӝt nút nào ÿó, ta phҧi ÿӏnh trӏ cho tҩt cҧ
các nút con cháu cӫa nó, và muӕn ÿӏnh trӏ cho nút gӕc ta phҧi ÿӏnh trӏ cho tҩt cҧ các nút trên cây. Sӕ
Oѭӧng các nút trên cây trò chѫi tuy hӳu hҥn nhѭng không phҧi là ít. Chҷng hҥn trong cây trò chѫi ca rô
nói trên, nӃu ta có bàn cӡ bao gӗm n ô thì có thӇ có tӟi n! nút trên cây (trong trѭӡng hӧp trên là 9!).
Ĉӕi vӟi các loҥi cӡ khác nhѭ cӡ vua chҷng hҥn, thì sӕ lѭӧng các nút còn lӟn hѫn nhiӅu. Ta gӑi là mӝt
Vӵ bùng nә tә hӧp các nút.
Chúng ta cӕ gҳng tìm mӝt cách sao cho khi ÿӏnh trӏ mӝt nút thì không nhҩt thiӃt phҧi ÿӏnh trӏ
cho tҩt cҧ các nút con cháu cӫa nó. Trѭӟc hӃt ta có nhұn xét nhѭ sau:
NӃu P là mӝt nút MAX và ta ÿang xét mӝt nút con Q cӫa nó (dƭ nhiên Q là nút MIN). Giҧ sӱ
Vp là mӝt giá trӏ tҥm cӫa P, Vq là mӝt giá trӏ tҥm cӫa Q và nӃu ta có Vp Vq thì ta không cҫn xét các
con chѭa xét cӫa Q nӳa. Vì nӃu có xét thì giá trӏ cӫa Q cNJng sӁ nhӓ hѫn hoһc bҵng Vq và do ÿó không
ҧnh hѭӣng gì ÿӃn Vp. Tѭѫng tӵ nӃu P là nút MIN (tҩt nhiên Q là nút MAX) và Vp Vq thì ta cNJng
không cҫn xét ÿӃn các con chѭa xét cӫa Q nӳa. ViӋc không xét tiӃp các con chѭa ÿѭӧc xét cӫa nút Q
Jӑi là viӋc cҳt tӍa Alpha-Beta các con cӫa nút Q.
Trên cѫ sӣ nhұn xét ÿó, ta nêu ra quy tҳc ÿӏnh trӏ cho mӝt nút không phҧi là nút lá trên cây nhѭ
sau:
1. Khӣi ÿҫu nút MAX có giá trӏ tҥm là - và nút MIN có giá trӏ tҥm là .
2. NӃu tҩt cҧ các nút con cӫa mӝt nút ÿã ÿѭӧc xét hoһc bӏ cҳt tӍa thì giá trӏ tҥm cӫa nút ÿó trӣ
thành giá trӏ cӫa nó.
3. NӃu mӝt nút MAX n có giá trӏ tҥm là V1 và mӝt nút con cӫa nó có giá trӏ là V2 thì ÿһt giá trӏ
Wҥm mӟi cӫa n là max (V1,V2). NӃu n là nút MIN thì ÿһt giá trӏ tҥm mӟi cӫa n là min (V1,V2).
4. Vұn dөng quy tҳc cҳt tӍa Alpha-Beta nói trên ÿӇ hҥn chӃ sӕ lѭӧng nút phҧi xét.Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 51
function cat_tia(Q: NodeType; mode: ModeType; Vp: real): real;
var C : NodeType ; { C là mӝt nút con cӫa nút Q}
Vq : real;
{Vq là giá trӏ tҥm cӫa Q, sau khi tҩt cҧ các con cӫa nút Q ÿã xét hoһc bӏ cҳt tӍa thì Vq là giá trӏ
Fӫa nút Q}
begin
if is_leaf(Q) then return ( Payoff(Q) )
else begin
{ Khӣi tҥo giá trӏ tҥm cho Q }
if mode = MAX then Vq := - else Vq := ;
{Xét các con cӫa Q, mӛi lҫn xác ÿӏnh ÿѭӧc giá trӏ cӫa mӝt nút con cӫa Q, ta phҧi ÿһt lҥi giá trӏ
Wҥm Vq và so sánh vӟi Vp ÿӇ có thӇ cҳt tӍa hay không}
Xét C là con trái nhҩt cӫa Q;
while C là con cӫa Q DO
if mode = MAX then begin
Vq:= max(Vq, Cat_tia(C, MIN, Vq));
if Vp Vq then return(Vq);
end
else begin Vq := min(Vq, Cat_tia(C, MAX, Vq));
if Vp Vq then return(Vq);
end;
return (Vq);
end;
end;
Ví dө 3-6: Vұn dөng quy tҳc trên ÿӇÿӏnh trӏ cho nút A trong cây trò chѫi trong ví dө 3-5.
A là nút MAX, lúc ÿҫu nó có giá trӏ tҥm là -, xét B là con cӫa A, B là nút lá nên giá trӏ cӫa nó
là giá trӏÿã ÿѭӧc gán 1, giá trӏ tҥm cӫa A bây giӡ là max (-,1) = 1. Xét con C cӫa A, C là nút MIN,
giá trӏ tҥm lúc ÿҫu cӫa C là . Xét con E cӫa C, E là nút MAX, giá trӏ tҥm cӫa E là -. Xét con I cӫa E,
I là nút lá nên giá trӏ cӫa nó là 0. Quay lui lҥi E, giá trӏ tҥm cӫa E bây giӡ là max (-,0) = 0. Vì E chӍ có
Pӝt con là I ÿã xét nên giá trӏ tҥm 0 trӣ thành giá trӏ cӫa E. Quay lui lҥi C, giá trӏ tҥm mӟi cӫa C là min
,0) = 0. A là nút MAX có giá trӏ tҥm là 1, C là con cӫa A, có giá trӏ tҥm là 0, 1>0 nên ta không cҫn
xét con F cӫa C nӳa. Nút C có hai con là E và F, trong ÿó E ÿã ÿѭӧc xét, F ÿã bӏ cҳt, vұy giá trӏ tҥm 0
Fӫa C trӣ thành giá trӏ cӫa nó. Sau khi có giá trӏ cӫa C, ta phҧi ÿһt lҥi giá trӏ tҥm cӫa A, nhѭng giá trӏ
Wҥm này không thay ÿәi vì max (1,0) = 1. TiӃp tөc xét nút D, D là nút MIN nên giá trӏ tҥm là , xét nút
con G cӫa D, G là nút MAX nên giá trӏ tҥm cӫa nó là -, xét nút con J cӫa G. Vì J là nút lá nên có giá
trӏ 0. Quay lui lҥi G, giá trӏ tҥm cӫa G bây giӡ là max (-,0) = 0 và giá trӏ tҥm này trӣ thành giá trӏ cӫa
G vì G chӍ có mӝt con J ÿã xét. Quay lui vӅ D, giá trӏ tҥm cӫa D bây giӡ là min (,0) = 0. Giá trӏ tҥm
này cӫa D nhӓ hѫn giá trӏ tҥm cӫa nút A MAX là cha cӫa nó nên ta cҳt tӍa con H chѭa ÿѭӧc xét cӫa D
và lúc này D có giá trӏ là 0. Quay lui vӅ A, giá trӏ tҥm cӫa nó vүn không thay ÿәi, nhѭng lúc này cҧ 3
con cӫa A ÿӅu ÿã ÿѭӧc xét nên giá trӏ tҥm 1 trӣ thành giá trӏ cӫa A. KӃt quҧÿѭӧc minh hӑa trong hình
sau:
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 52
III.4.3-Kӻ thuұt nhánh cұn
Vӟi các bài toán tìm phѭѫng án tӕi ѭu, nӃu chúng ta xét hӃt tҩt cҧ các phѭѫng án thì mҩt rҩt
nhiӅu thӡi gian, nhѭng nӃu sӱ dөng phѭѫng pháp tham ăn thì phѭѫng án tìm ÿѭӧc chѭa hҷn ÿã là
phѭѫng án tӕi ѭu. Nhánh cұn là kӻ thuұt xây dӵng cây tìm kiӃm phѭѫng án tӕi ѭu, nhѭng không xây
Gӵng toàn bӝ cây mà sӱ dөng giá trӏ cұn ÿӇ hҥn chӃ bӟt các nhánh.
Cây tìm kiӃm phѭѫng án có nút gӕc biӇu diӉn cho tұp tҩt cҧ các phѭѫng án có thӇ có, mӛi nút
lá biӇu diӉn cho mӝt phѭѫng án nào ÿó. Nút n có các nút con tѭѫng ӭng vӟi các khҧ năng có thӇ lӵa
chӑn tұp phѭѫng án xuҩt phát tӯ n. Kӻ thuұt này gӑi là phân nhánh.
Vӟi mӛi nút trên cây ta sӁ xác ÿӏnh mӝt giá trӏ cұn. Giá trӏ cұn là mӝt giá trӏ gҫn vӟi giá cӫa các
phѭѫng án. Vӟi bài toán tìm min ta sӁ xác ÿӏnh Fұn dѭӟi còn vӟi bài toán tìm max ta sӁ xác ÿӏnh Fұn
trên. Cұn dѭӟi là giá trӏ nhӓ hѫn hoһc bҵng giá cӫa phѭѫng án, ngѭӧc lҥi cұn trên là giá trӏ lӟn hѫn
hoһc bҵng giá cӫa phѭѫng án.
ĈӇ dӉ hình dung ta sӁ xét hai bài toán quen thuӝc là bài toán TSP và bài toán cái ba lô.
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 53
Bài toán ÿѭӡng ÿi cӫa ngѭӡi giao hàng
Phân nhánh
Cây tìm kiӃm phѭѫng án là cây nhӏ phân trong ÿó:
· Nút gӕc là nút biӇu diӉn cho cҩu hình bao gӗm tҩt cҧ các phѭѫng án.
· Mӛi nút sӁ có hai con, con trái biӇu diӉn cho cҩu hình bao gӗm tҩt cҧ các phѭѫng án chӭa
Pӝt cҥnh nào ÿó, con phҧi biӇu diӉn cho cҩu hình bao gӗm tҩt cҧ các phѭѫng án không chӭa cҥnh ÿó
(các cҥnh ÿӇ xét phân nhánh ÿѭӧc thành lұp tuân theo mӝt thӭ tӵ nào ÿó, chҷng hҥn thӭ tӵ tӯÿLӇn).
· Mӛi nút sӁ kӃ thӯa các thuӝc tính cӫa tә tiên cӫa nó và có thêm mӝt thuӝc tính mӟi (chӭa
hay không chӭa mӝt cҥnh nào ÿó).
· Nút lá biӇu diӉn cho mӝt cҩu hình chӍ bao gӗm mӝt phѭѫng án.
· ĈӇ quá trình phân nhánh mau chóng tӟi nút lá, tҥi mӛi nút ta cҫn có mӝt quyӃt ÿӏnh bә
sung dӵa trên nguyên tҳc là mӑi ÿӍnh trong chu trình ÿӅu có cҩp 2 và không tҥo ra mӝt chu trình thiӃu.
Ví dө 3-7: Xét bài toán TSP có 5 ÿӍnh vӟi ÿӝ dài các cҥnh ÿѭӧc cho trong hình 3-12.
Các cҥnh theo thӭ tӵ tӯÿLӇn ÿӇ xét là:
ab, ac, ad, ae, bc, bd, be, cd, ce và de.
Nút gӕc A cӫa cây bao gӗm tҩt cҧ các phѭѫng án.
Hai con cӫa A là B và C, trong ÿó B bao gӗm tҩtcҧ các phѭѫng án chӭa cҥnh ab, C bao gӗm tҩt
Fҧ các phѭѫng án không chӭa ab.
Hai con cӫa B là D và E. Nút D bao gӗm tҩt cҧ các phѭѫng án chӭa ac. Vì các phѭѫng án này
Yӯa chӭa ab (kӃ thӯa cӫa B) vӯa chӭa ac nên ÿӍnh a ÿã ÿӫ cҩp hai nên D không thӇ chӭa ad và ae. Nút
E bao gӗm tҩt cҧ các phѭѫng án không chӭa ac..
Ta ÿѭӧc cây (chѭa ÿҫy ÿӫ ) trong hình 3-13
Upload by Kenhdaihoc.com
.
Collected by The_Wall (11/10/2005)
Giáo trình môn Phân tích Giɠi Thuɪt – ĈɝI +͌C CɣN THɆ ........................................................................Trang 54
Trong ÿó ký hiӋu có nghƭa là không chӭa cҥnh ab.
Tính cұn dѭӟi
Ĉây là bài toán tìm min nên ta sӱ dөng Fұn dѭӟi. Cұn dѭӟi tҥi mӛi nút là mӝt sӕ nhӓ hѫn hoһc
Eҵng giá cӫa tҩt cҧ các phѭѫng án ÿѭӧc biӇu diӉn bӣi nút ÿó. Giá cӫa mӝt phѭѫng án ӣÿây là tәng ÿӝ
dài cӫa mӝt chu trình.
ĈӇ tính cұn dѭӟi cӫa nút gӕc, mӛi ÿӍnh ta chӑn hai cҥnh có ÿӝ dài nhӓ nhҩt. Cұn dѭӟi cӫa nút
Jӕc bҵng tәng ÿӝ dài tҩt cҧ các cҥnh ÿѭӧc chӑn chia cho 2.
Ví dө 3-8: Vӟi sӕ liӋu cho trong ví dө 3-7 nói trên, ta tính
Các file đính kèm theo tài liệu này:
- Giao trinh phan tich Giai thuat.pdf