data:image/s3,"s3://crabby-images/79253/7925394cf39e394c3cb1a7809e9218b9e0c61153" alt="MIT計算機開放課_第1頁"
data:image/s3,"s3://crabby-images/1dc11/1dc11bc7f3823c190e05fc66f88e05aa539ca665" alt="MIT計算機開放課_第2頁"
data:image/s3,"s3://crabby-images/56372/56372c67f458e6ec194384c694416f778f7a95ee" alt="MIT計算機開放課_第3頁"
data:image/s3,"s3://crabby-images/e439e/e439ef85909c5ddd7078652d8b6e2084e017e5a8" alt="MIT計算機開放課_第4頁"
data:image/s3,"s3://crabby-images/aa69c/aa69cb74b8348710e2525eb612d8976a4dd316cf" alt="MIT計算機開放課_第5頁"
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)
文檔簡介
IntroductiontoAlgorithms
6.046J/18.401J
LECTURE1
AnalysisofAlgorithms
?Insertionsort
?Asymptoticanalysis
?Mergesort
?Recurrences
Prof.CharlesE.Leiserson
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
Courseinformation
1.Staff8.Coursewebsite
2.Distancelearning9.Extrahelp
3.Prerequisites10.Registration
4.Lectures11.Problemsets
5.Recitations12.Describingalgorithms
6.Handouts13.Gradingpolicy
7.Textbook14.Collaborationpolicy
September7,2005IntroductiontoAlgorithmsL1.2
Analysisofalgorithms
Thetheoreticalstudyofcomputer-program
performanceandresourceusage.
Whafsmoreimportantthanperformance?
modularity?user-friendliness
correctness?programmertime
maintainability?simplicity
functionality?extensibility
robustness?reliability
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsL1.3
Whystudyalgorithmsand
、、7performance?
?Algorithmshelpustounderstandscalability.
?Performanceoftendrawsthelinebetweenwhat
isfeasibleandwhatisimpossible.
?Algorithmicmathematicsprovidesalanguage
fbrtalkingaboutprogrambehavior.
?Performanceisthecurrencyofcomputing.
?Thelessonsofprogramperformancegeneralize
toothercomputingresources.
?Speedisfun!
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.4
ALGORITHMS
Theproblemofsorting
Input:sequence〈%,%夕???,%〉°fnumbers.
Output:permutation*,…,such
f
thata\<a\<--<an.
Example:
Input:824936
Output:234689
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsL1.5
ALGORITHMS
.0mmmD
Insertionsort
rINSERTION-SORT(A,n)>A[1..n]
for/<—2ton
dokey^A[j]
“pseudocode"\ijj—1
whilei>0andA[i]>key
doA[i+1]A[i]
i?-z—1
A\i+\}=key
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsL1.6
ALGORITHMS
.0mmmD
Insertionsort
rINSERTION-SORT(A,n)>A[1..n]
for/<—2ton
dokey^A[j]
“pseudocode"\ijj—1
whilei>0andA[i]>key
doA[i+1]A[i]
i?-z—1
A\i+\}=key
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsL1.7
ALGORITHMS
V_____
:、、,Exampleofinsertionsort
824936
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsL1.8
ALGORITHMS
V_____
:、、,Exampleofinsertionsort
824936
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsL1.9
ALGORITHMS
V_____
:、、,Exampleofinsertionsort
824936
284936
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.10
ALGORITHMS
:、、?Exampleofinsertionsort
824936
284936
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.11
ALGORITHMS
V_____
Exampleofinsertionsort
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.12
Exampleofinsertionsort
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.13
Exampleofinsertionsort
6
6
6
6
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.14
Exampleofinsertionsort
6
6
6
6
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.15
ALGORITHMS
Exampleofinsertionsort
824936
284936
*—
248936
6
6
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.16
ALGORITHMS
Exampleofinsertionsort
824936
284936
*—
248936
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.17
ALGORITHMS
V_____
:、、,Exampleofinsertionsort
824936
284936
248936
234689done
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.18
ALGORITHMS
:、「Runningtime
?Therunningtimedependsontheinput:an
alreadysortedsequenceiseasiertosort.
?Parameterizetherunningtimebythesizeof
theinput,sinceshortsequencesareeasierto
sortthanlongones.
?Generally,weseekupperboundsonthe
runningtime,becauseeverybodylikesa
guarantee.
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.19
ALGORITHMS
.—
:、、,Kindsofanalyses
Worst-case:(usually)
?T(n)=maximumtimeofalgorithm
onanyinputofsizen.
Average-case:(sometimes)
?T(n)=expectedtimeofalgorithm
overallinputsofsizen.
?Needassumptionofstatistical
distributionofinputs.
Best-case:(bogus)
?Cheatwithaslowalgorithmthat
worksfastonsomeinput.
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.20
ALGORITHMS
Machine-independenttime
Whatisinsertionsort'sworst-casetime?
?Itdependsonthespeedofourcomputer:
?relativespeed(onthesamemachine)5
?absolutespeed(ondifferentmachines).
BIGIDEA:
?Ignoremachine-dependentconstants.
?LookatgrowthofT(n)as〃一oc.
^AsymptoticAnalysis^
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.21
ALGORITHMS
?-notation
Math:
0(g(n))={/(〃):thereexistpositiveconstantsc19c2,and
n0suchthat0<Cjg(n)</(n)<c2g(n)
fbralln>n0}
Engineering:
?Droplow-orderterms;ignoreleadingconstants.
?Example:3"+90/—5〃+6046=0(^3)
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.22
ALGORITHMS
:、、,Asymptoticperformance
Whenngetslargeenough,a0(zz2)algorithm
alwaysbeatsa0(H3)algorithm.
?Weshouldn'tignore
asymptoticallyslower
algorithms,however.
?Real-worlddesign
situationsoftencallfora
carefulbalancingof
engineeringobjectives.
?Asymptoticanalysisisa
usefultooltohelpto
structureourthinking.
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.23
ALGORITHMS
Insertionsortanalysis
Worstcase:Inputreversesorted.
n
T(〃)=[arithmeticseries]
六2
Averagecase:Allpermutationsequallylikely.
n
-(〃)=£。(〃2)=?伍2)
j=2
Isinsertionsortafastsortingalgorithm?
?Moderatelyso,forsmalln.
?Notatall,forlargen.
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.24
ALGORITHMS
,Mergesort
MERGE-SORTA[1..n\
1.If/z=1,done.
2.Recursivelysort4[1..「〃/2]]
andA[[n/2~\+l..n].
"Merge"the2sortedlists.
Keysubroutine:MERGE
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.25
ALGORITHMS
、、、、Mergingtwosortedarrays
2012
1311
79
21
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsL1.26
ALGORITHMS
、、、、Mergingtwosortedarrays
2012
1311
79
y
1
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.27
ALGORITHMS
.annxnxxxD
Mergingtwosortedarrays
2012III2012
13111311
7979
芋|2
1
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsL1.28
ALGORITHMS
Mergingtwosortedarrays
20122012
13111311
7979
2TT
12
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.29
ALGOMTHMS
.annxnnrc
Mergingtwosortedarrays
2012
1311
79
i2
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsL1.30
Mergingtwosortedarrays
201220
131113
127
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsL1.31
Mergingtwosortedarrays
20122012
13111311
9
1
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsL1.32
Mergingtwosortedarrays
20122012
13111311
1279
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsL1.33
Mergingtwosortedarrays
201212
11
27
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsL1.34
Mergingtwosortedarrays
20122012
1311
12711
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsL1.35
Mergingtwosortedarrays
201220122012
131113
111
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsL1.36
ALGORiTHJvlS
.amxxnxnD
Mergingtwosortedarrays
20122012
1311
11112
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsL1.37
ALGORITHMS
.ami?
Mergingtwosortedarrays
1112
Time=0(77)tomergeatotal
ofnelements(lineartime).
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsL1.38
ALGORITHMS
Analyzingmergesort
T?MERGE-SORT^4[1..n\
「6⑴1.If撲=19done.
(2T(〃/2)2.Recursivelysort4[1..「〃/21]
Abuse/and/[[n/2~]+l..n].
/。⑺
3.“Merge”the2sortedlists
Sloppiness:ShouldbeT(「〃/2])+T(5/2」),
butitturnsoutnottomatterasymptotically.
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsL1.39
ALGORITHMS
Recurrenceformergesort
r0(i)if/?=i;
T(〃)=
Y、2T(〃/2)+05)if〃>1.
?Weshallusuallyomitstatingthebase
casewhen7\n)=0(1)fbrsufficiently
smalln,butonlywhenithasnoeffecton
theasymptoticsolutiontotherecurrence.
?CLRSandLecture2provideseveralways
tofindagoodupperboundonT(n).
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.40
ALGORITHMS
Recursiontree
SolveT(n)=2T(M2)+cn,wherec>0isconstant.
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsL1.41
ALGORITHMS
Recursiontree
SolveT(n)=2T(M2)+cn,wherec>0isconstant.
?、?/p>
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.42
ALGORITHMS
.U一3
二,Recursiontree
SolveT(n)=2T(n/2)+cn,wherec>0isconstant.
cn
T(〃/2)T(〃/2)
Copyright?2001-5Erik.D.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.43
ALGORITHMS
Recursiontree
SolveT(n)=2T(M2)+cn,wherec>0isconstant.
cn
cn/2cn/2
//、
T(T?/4)T(M4)T(TI/4)T(〃/4)
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.44
ALGORITHMS
Recursiontree
Solver(n)=2T(M2)+cn.wherec>0isconstant.
cn/4cnJ4c〃/4cnl4
?(1)
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.45
ALGORITHMS
Recursiontree
Solver(n)=2T(M2)+cn.wherec>0isconstant.
"—1g"cn14cnl4cn/4cn/4
?(1)
Copyright?2001-5ErikD.DemaineandCharlesE.Leiserson
September7,2005IntroductiontoAlgorithmsLI.46
ALGORITHMS
Recursiontree
SolveT(n)=2T(〃/2)+cn,wherec>0isconstant.
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 建筑合同范本包括
- 訂購飛機合同范本
- 網(wǎng)絡(luò)代銷合同范本
- 政府租賃合同范本
- 第2課時 軸對稱(二)(教學(xué)設(shè)計)-2023-2024學(xué)年三年級下冊數(shù)學(xué)北師大版
- 托管流轉(zhuǎn)土地合同范本
- 土地使用權(quán)不動產(chǎn)轉(zhuǎn)讓合同范本
- 學(xué)校電工聘用合同范本
- 常用版物流運輸合同
- 商品房買賣合同示范版
- 2025年中國工程建設(shè)行業(yè)現(xiàn)狀、發(fā)展環(huán)境及投資前景分析報告
- 初級電工證考試試題庫(含答案)
- 《海瀾之家公司績效管理現(xiàn)狀、問題及優(yōu)化對策(7600字論文)》
- 小學(xué)四年級英語教學(xué)反思3篇
- DB1509T 0025-2024 肉牛舍設(shè)計與建筑技術(shù)規(guī)范
- 上海室內(nèi)裝飾施工合同示范文本2024年
- 四年級語文下冊 第一單元 字詞專項練習(xí) (含答案)(部編版)
- 2024版2024年《汽車文化》全套教案
- 房地產(chǎn) -中建科工五大類型項目成本指標(biāo)庫
- 2024小紅書保健品行業(yè)營銷通案
- 未來網(wǎng)絡(luò)支撐下的數(shù)字身份體系:產(chǎn)業(yè)和技術(shù)發(fā)展趨勢(2024年)定稿版本
評論
0/150
提交評論