下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、算法分析的兩個(gè)主要方面算法分析是對一個(gè)算法需要多少計(jì)算時(shí)間和存儲空間作定量的分析。算法(Algorithm )是解題的步驟,可以把算法定義成解一確定類問題的任意一種特殊的方法。在計(jì)算機(jī)科學(xué)中,算法要用計(jì)算機(jī)算法語言描述,算法代表用計(jì)算機(jī)解一類問題的精確、有效的方法。算法是一組有窮的規(guī)則,它們規(guī)定了解決某一特定類型問題的一系列運(yùn)算,是對解題方案內(nèi)的準(zhǔn)確與完整地描述。制定一個(gè)算法,一般要經(jīng)過設(shè)計(jì)、確認(rèn)、分析、編碼、測試、調(diào) 試、計(jì)時(shí)等階段。算法+數(shù)據(jù)結(jié)構(gòu)=程序,求解一個(gè)給定的可計(jì)算或可解的問題,不同的人可以編寫出不同的程序,來解決同一個(gè)問題,這里存在兩個(gè)問題:一是與計(jì)算方法密切相關(guān)的算法問題;二是
2、程序設(shè)計(jì)的技術(shù)問題。算法和程序之間存在密切的關(guān)系。分析算法可以預(yù)測這一算法適合在什么樣的環(huán)境中有效地運(yùn)行,對解決同一問題的不同算法的有效性作出比較。通常對于一個(gè)實(shí)際問題的解決,可以提出若干個(gè)算法,如何從這些可行的算法中找出最有效的算法呢?或者有了一個(gè)解決實(shí)際問題的算法后,如何來評價(jià)它的好壞呢?這些問題都需要通過算法分析來確定。評價(jià)算法分析性能的標(biāo)準(zhǔn)主要從算法執(zhí)行時(shí)間和占用存儲空間兩 個(gè)方面進(jìn)行考慮,即通過分析算法執(zhí)行所需要的時(shí)間和存儲空間來判斷一個(gè)算法的優(yōu)劣。時(shí)間復(fù)雜度一個(gè)程序的時(shí)間復(fù)雜度是指程序運(yùn)行從開始到結(jié)束所需要的時(shí)間。影響因素一個(gè)算法是由控制結(jié)構(gòu) (順序、分支和循環(huán)3種)和原操作(指固
3、定數(shù)據(jù)類型的操作)構(gòu)成的,其執(zhí)行時(shí)間取決于兩者的綜合效果。為了便于比較同一問題的不同算法,通常的做法是:從算法中選取一種對于所研究的問題來說基本運(yùn)算的原操作,以該原操作重復(fù)執(zhí)行的次數(shù)作為算法的時(shí)間度量。一般情況下,算法中原操作重復(fù)執(zhí)行次數(shù)是規(guī)模n的某個(gè)函數(shù)T(n)。許多時(shí)候要精確的計(jì)算 T(n)是困難的,引入漸進(jìn)時(shí)間復(fù)雜度在數(shù)量上估計(jì)一個(gè)算法的 執(zhí)行時(shí)間,也能夠達(dá)到分析算法的目的。計(jì)算方法計(jì)算時(shí)間復(fù)雜度的時(shí)候,主要考慮算法中最高階項(xiàng)的開銷,只要找出算法中最高階的復(fù)雜度,就可以忽略低階和常數(shù)的復(fù)雜度。引入數(shù)學(xué)符號“O來估算算法時(shí)間復(fù)雜度,漸進(jìn)時(shí)間復(fù)雜度的表示方法:F(n)=O(g(n), 其定義
4、為,若F(n)和g(n)是定義在正整數(shù)集合上的兩個(gè)函數(shù),則F(n)=O(g(n)表示存在正的對一組特定個(gè)數(shù)的元素進(jìn)行排序。對該組元素的排序是排序問題的一個(gè)實(shí)例。元素個(gè)數(shù)可視對一組特定個(gè)數(shù)的元素進(jìn)行排序。對該組元素的排序是排序問題的一個(gè)實(shí)例。元素個(gè)數(shù)可視常數(shù)C和no,使得當(dāng)nno時(shí),都滿足0 F(n) Cg(n)。換句話說,就是這兩個(gè)函數(shù)當(dāng)整 形自變量n趨于無窮大時(shí),兩者的比值是一個(gè)不等于0的常數(shù)。當(dāng)要計(jì)算某個(gè)算法的時(shí)間復(fù)雜度F(n)時(shí),可以找一個(gè)更簡單的、階數(shù)相同的簡單算法g(n)等同計(jì)算,這里的g( n)是指替代函數(shù),它具有和原算法一樣更高階復(fù)雜度。例如,一個(gè)程序的實(shí)際執(zhí)行時(shí)間為:T(n)=
5、3n 3+4n 2+5 ,則T(n)=O(n 3)。使用0記號表示的算法的時(shí)間復(fù)雜度,稱為算法的漸進(jìn)時(shí)間復(fù)雜度。常見的漸進(jìn)時(shí)間復(fù)雜度通常用0(1)表示常數(shù)計(jì)算時(shí)間。常見的漸進(jìn)時(shí)間復(fù)雜度有:O (1) O (IOg2 ) O (R) O (JnIugJ CO (?) O (存) O (2n)規(guī)則為了便于估算一個(gè)算法的時(shí)間復(fù)雜度,我們約定一下幾條可操作的規(guī)則:讀寫單個(gè)常量或單個(gè)變量、賦值、算術(shù)運(yùn)算、關(guān)系運(yùn)算、邏輯運(yùn)算等,計(jì)為一個(gè) 單位時(shí)間。 條件語句if(C)s,執(zhí)行時(shí)間為(條件C的執(zhí)行時(shí)間)+ (語句塊S的執(zhí)行時(shí)間)。 條件語句if(C)s1 else s2 ,執(zhí)行時(shí)間為(條件 C的執(zhí)行時(shí)間)+
6、 (語句塊si和s2 中執(zhí)行時(shí)間最長的那個(gè)時(shí)間)。 SWitCh.case 語句的執(zhí)行時(shí)間是所有CaSe子句中,執(zhí)行時(shí)間最長的語句塊。訪問一個(gè)數(shù)據(jù)的單個(gè)元素或一個(gè)結(jié)構(gòu)體變量的單個(gè)元素只需要一個(gè)單位時(shí)間。執(zhí)行一個(gè)for循環(huán)語句需要的時(shí)間等于執(zhí)行該循環(huán)體所需要時(shí)間乘上循環(huán)次數(shù)。 執(zhí)行一個(gè) WhiIe(C)s循環(huán)語句或者執(zhí)行一個(gè)dos WhiIe(C)語句,需要的時(shí)間等于計(jì)算條件表達(dá)式 C的時(shí)間與執(zhí)行循環(huán) S的時(shí)間之和再乘以循環(huán)的次數(shù)。對于嵌套結(jié)構(gòu),算法的時(shí)間復(fù)雜度由嵌套最深層語句的執(zhí)行次數(shù)決定的。對于函數(shù)調(diào)用語句,它們需要的時(shí)間包括兩部分,一部分用于實(shí)現(xiàn)控制轉(zhuǎn)移,另 一部分用于執(zhí)行函數(shù)本身。空間復(fù)
7、雜度一個(gè)算法的空間復(fù)雜度是指程序運(yùn)行從開始到結(jié)束所需的存儲空間大小。程序的一次運(yùn)行是針對所求解的問題的某一特定實(shí)例而言的。例如,求解排序問題的排序算法每次執(zhí)行是為該實(shí)例的特征。程序運(yùn)行所需要的存儲空間主要包括兩部分。固定部分這部分空間與所處理數(shù)據(jù)的大小和個(gè)數(shù)無關(guān),或者稱與問題的實(shí)例的特征無關(guān)。主要包括程序代碼、常量、簡單變量、定長成分的結(jié)構(gòu)變量所占的空間??勺儾糠诌@部分空間大小與算法在某次執(zhí)行中處理的特定數(shù)據(jù)的大小和規(guī)模有關(guān)。例如100個(gè)數(shù)據(jù)元素的排序算法與 1000個(gè)數(shù)據(jù)元素的排序算法所需要的存儲空間顯然是不同的。算法在運(yùn)行過程中臨時(shí)占用的存儲空間隨算法的不同而異。有的算法只需要占用少量的存
8、儲空間,而且不隨問題規(guī)模的大小而改變,有的算法需要占用的存儲空間數(shù)隨著問題規(guī)模n的增大而增大,此時(shí)按照最壞情況來分析應(yīng)用在查找引擎優(yōu)化范疇里邊有一個(gè)疑問常常讓人感受捉摸不透,到底是什么樣的排序要素結(jié)尾決議了網(wǎng)頁的排名。而每個(gè)查找引擎公司都將其的查找引擎算法維護(hù)的極端緊密,只要很少很少的一有些的公司能有時(shí)機(jī)看到這些算法的全貌。并且就算是有時(shí)機(jī)看到這些算法的真實(shí)容貌,要想領(lǐng)悟到話,還得具有深沉的數(shù)學(xué)功底。這使得對查找引擎優(yōu)化整個(gè)概念的曉得變得很艱難算法應(yīng)用和問題解決為了更快的回來查找成果給用戶,查找引擎公司通常都會將巨大的運(yùn)算簡化,查找引擎所運(yùn)用的這些算法都會設(shè)置一個(gè)用于比擬判別網(wǎng)站價(jià)值的根底準(zhǔn)則
9、。不一樣的查找引擎所運(yùn)用的基準(zhǔn)是不一樣的。例如,在Google的算法中就運(yùn)用了 200多個(gè)要從來構(gòu)建這個(gè)基準(zhǔn)。經(jīng)過很多查找引擎愛好者的研討與查找引擎的共享,大家也大約的曉得了查找引擎算法中的重要有些??墒且霑缘貌檎乙娴母鱾€(gè)細(xì)節(jié)那是不能夠的工作,更何況Google簡直每天都會對算法做出很多的修改。有些修正會形成很大的影響,有些則僅僅一些細(xì)微的修正。查找算法的不斷改變使得大家更難知曉算法的各個(gè)細(xì)節(jié)。算法優(yōu)化在確定了算法之后,在構(gòu)建網(wǎng)站(或是為SEo更新網(wǎng)站)時(shí)就能有一些能夠遵照的準(zhǔn)則。 在這些準(zhǔn)則中,最重要的就是要以人為本,而不要為查找引擎描繪網(wǎng)站。所以,若是創(chuàng)立的 網(wǎng)站是關(guān)于春季休假的, 就
10、應(yīng)該為用戶供給與春季休假有關(guān)的信息和連接。在爬蟲檢索網(wǎng)站時(shí),若是網(wǎng)站中含有指向機(jī)票預(yù)訂網(wǎng)站、假目網(wǎng)站、花園展現(xiàn)網(wǎng)站或其他與春季休假有關(guān)的網(wǎng)站的連接,爬蟲就會跟蹤這些連接,并經(jīng)過算法判別這些網(wǎng)站的關(guān)聯(lián)性。若是這些網(wǎng)站都與春季休假有親近的聯(lián)系, 網(wǎng)站就能取得較高的排名。 若是網(wǎng)站連接的都是一些無關(guān)的網(wǎng)站, 就有能夠查找爬蟲視為連接場,網(wǎng)站排名會很差,乃至遭到屏蔽。其間難以確定的是,究竟網(wǎng)站中必須有多少關(guān)聯(lián)網(wǎng)站的連接,又能夠有多少無關(guān)網(wǎng)站的連接。從常理上說,若是描繪一個(gè)關(guān)于春季休假的網(wǎng)頁,抱負(fù)的狀況是進(jìn)出這個(gè)網(wǎng)頁的連接來自關(guān)聯(lián)的網(wǎng)頁。廣告能夠是一個(gè)破例,但這會被明確地標(biāo)明為廣告。 另一種狀況就是網(wǎng)站上
溫馨提示
- 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)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 技術(shù)開發(fā)合同(2篇)
- 2025年度數(shù)據(jù)中心通風(fēng)排煙系統(tǒng)建設(shè)與維護(hù)服務(wù)合同2篇
- 個(gè)人向公司借款合同(2024年)
- 2025版民房建筑工程勞務(wù)分包合同4篇
- 2025年建筑保溫材料專用黏結(jié)劑銷售合同3篇
- 2025年度農(nóng)用車出口貿(mào)易代理合同范本3篇
- 2025年度能源行業(yè)個(gè)人勞務(wù)派遣及安全生產(chǎn)合同3篇
- 2025年度個(gè)人企業(yè)全額承包經(jīng)營服務(wù)合同規(guī)范3篇
- 2025年度智能培訓(xùn)班租賃合同范本3篇
- 二零二五模具加工企業(yè)臨時(shí)工用工合同范本4篇
- 副總經(jīng)理招聘面試題與參考回答(某大型國企)2024年
- PDCA循環(huán)提高護(hù)士培訓(xùn)率
- 2024-2030年中國智慧水務(wù)行業(yè)應(yīng)用需求分析發(fā)展規(guī)劃研究報(bào)告
- 《獅子王》電影賞析
- 河北省保定市定州市2025屆高二數(shù)學(xué)第一學(xué)期期末監(jiān)測試題含解析
- 中醫(yī)護(hù)理人文
- 2024-2030年中國路亞用品市場銷售模式與競爭前景分析報(bào)告
- 貨物運(yùn)輸安全培訓(xùn)課件
- 前端年終述職報(bào)告
- 2024小說推文行業(yè)白皮書
- 市人民醫(yī)院關(guān)于開展“改善就醫(yī)感受提升患者體驗(yàn)主題活動”2023-2025年實(shí)施方案及資料匯編
評論
0/150
提交評論