1,
演算法複雜度是在《資料結構》這門課程的第一章裡出現的,因為它稍微涉及到一些數學問題,所以很多同學感覺很難,加上這個概念也不是那麼具體,更讓許多同學複習起來無從下手,下面我們就這個問題給各位考生進行分析。
首先了解一下幾個概念。乙個是時間複雜度,乙個是漸近時間複雜度。前者是某個演算法的時間耗費,它是該演算法所求解問題規模n的函式,而後者是指當問題規模趨向無窮大時,該演算法時間複雜度的數量級。
當我們評價乙個演算法的時間效能時,主要標準就是演算法的漸近時間複雜度,因此,在演算法分析時,往往對兩者不予區分,經常是將漸近時間複雜度t(n)=o(f(n))簡稱為時間複雜度,其中的f(n)一般是演算法中頻度最大的語句頻度。
此外,演算法中語句的頻度不僅與問題規模有關,還與輸入例項中各元素的取值相關。但是我們總是考慮在最壞的情況下的時間複雜度。以保證演算法的執行時間不會比它更長。
常見的時間複雜度,按數量級遞增排列依次為:常數階o(1)、對數階o(log2n)、線性階o(n)、線性對數階o(nlog2n)、平方階o(n^2)、立方階o(n^3)、k次方階o(n^k)、指數階o(2^n)。
下面我們通過例子加以說明,讓大家碰到問題時知道如何去解決。
1、設三個函式f,g,h分別為 f(n)=100n^3+n^2+1000 , g(n)=25n^3+5000n^2 , h(n)=n^1.5+5000nlgn
請判斷下列關係是否成立:
(1) f(n)=o(g(n))
(2) g(n)=o(f(n))
(3) h(n)=o(n^1.5)
(4) h(n)=o(nlgn)
這 裡我們複習一下漸近時間複雜度的表示法t(n)=o(f(n)),這裡的"o"是數學符號,它的嚴格定義是"若t(n)和f(n)是定義在正整數集合上的 兩個函式,則t(n)=o(f(n))表示存在正的常數c和n0 ,使得當n≥n0時都滿足0≤t(n)≤c?f(n)。"用容易理解的話說就是這兩個函式當整型自變數n趨向於無窮大時,兩者的比值是乙個不等於0的常 數。這麼一來,就好計算了吧。
◆ (1)成立。題中由於兩個函式的最高次項都是n^3,因此當n→∞時,兩個函式的比值是乙個常數,所以這個關係式是成立的。
◆ (2)成立。與上同理。
◆ (3)成立。與上同理。
◆ (4)不成立。由於當n→∞時n^1.5比nlgn遞增的快,所以h(n)與nlgn的比值不是常數,故不成立。
2、設n為正整數,利用大"o"記號,將下列程式段的執行時間表示為n的函式。
(1) i=1; k=0
while(i1
while (x>=(y+1)*(y+1))
y++;
解答:t(n)=n1/2 ,t(n)=o(n1/2), 最壞的情況是y=0,那麼迴圈的次數是n1/2次,這是乙個按平方根階遞增的函式。
(3) x=91; y=100;
while(y>0)
if(x>100)
else x++;
解答: t(n)=o(1), 這個程式看起來有點嚇人,總共迴圈執行了1000次,但是我們看到n沒有? 沒。這段程式的執行是和n無關的,就算它再迴圈一萬年,我們也不管他,只是乙個常數階的函式。
有如下複雜度關係
c < log2n < n < n * log2n < n^2 < n^3 < 2^n < 3^n < n!
其中c是乙個常量,如果乙個演算法的複雜度為c 、 log2n 、n 、 n*log2n ,那麼這個演算法時間效率比較高 ,如果是 2^n , 3^n ,n!,那麼稍微大一些的n就會令這個演算法不能動了,居於中間的幾個則差強人意。2,
學習演算法的同學,如果不知道計算乙個演算法的時間複雜度該如何計算,其實是一件很丟臉的事情。最近選修了高階演算法這門課,由於時間緊張,原本就想混過去算了,但是不料考試的時候有40%的題目是計算時間複雜度的,乾脆就好好的總結一下。
概念我也不講了,大家都清楚。關鍵講講怎麼計算比較實際一點。
求解演算法的時間複雜度的具體步驟是:
⑴ 找出演算法中的基本語句;
演算法中執行次數最多的那條語句就是基本語句,通常是最內層迴圈的迴圈體。
⑵ 計算基本語句的執行次數的數量級;
只需計算基本語句執行次數的數量級,這就意味著只要保證基本語句執行次數的函式中的最高次冪正確即可,可以忽略所有低次冪和最高次冪的係數。這樣能夠簡化演算法分析,並且使注意力集中在最重要的一點上:增長率。
⑶ 用大ο記號表示演算法的時間效能。
將基本語句執行次數的數量級放入大ο記號中。
如果演算法中包含巢狀的迴圈,則基本語句通常是最內層的迴圈體,如果演算法中包含並列的迴圈,則將並列迴圈的時間複雜度相加。例如:
for (i=1; i<=n; i++)
x++;
for (i=1; i<=n; i++)
for (j=1; j<=n; j++)
x++;
第乙個for迴圈的時間複雜度為ο(n),第二個for迴圈的時間複雜度為ο(n2),則整個演算法的時間複雜度為ο(n+n2)=ο(n2)。
常見的演算法時間複雜度由小到大依次為:
ο(1)<ο(log2n)<ο(n)<ο(nlog2n)<ο(n2)<ο(n3)<…<ο(2n)<ο(n!)
ο(1)表示基本語句的執行次數是乙個常數,一般來說,只要演算法中不存在迴圈語句,其時間複雜度就是ο(1)。ο(log2n)、ο(n)、ο(nlog2n)、ο(n2)和ο(n3)稱為多項式時間,而ο(2n)和ο(n!)稱為指數時間。計算機科學家普遍認為前者是有效演算法,把這類問題稱為p類問題,而把後者稱為np問題。
這只能基本的計算時間複雜度,具體的執行還會與硬體有關。
時間複雜度計算
定義 如果乙個問題的規模是n,解這一問題的某一演算法所需要的時間為t n 它是n的某一函式 t n 稱為這一演算法的 時間複雜性 當輸入量n逐漸加大時,時間複雜性的極限情形稱為演算法的 漸近時間複雜性 我們常用大o表示法表示時間複雜性,注意它是某乙個演算法的時間複雜性。大o表示只是說有上界,由定義如...
計算時間複雜度
求解演算法的時間複雜度的具體步驟是 找出演算法中的基本語句 演算法中執行次數最多的那條語句就是基本語句,通常是最內層迴圈的迴圈體。計算基本語句的執行次數的數量級 只需計算基本語句執行次數的數量級,這就意味著只要保證基本語句執行次數的函式中的最高次冪正確即可,可以忽略所有低次冪和最高次冪的係數。這樣能...
計算 時間複雜度
一 概念時間複雜度是總運算次數表示式中受n的變化影響最大的那一項 不含係數 比如 一般總運算次數表示式類似於這樣 a 2 n b n 3 c n 2 d n lg n e n f a 0時,時間複雜度就是o 2 n a 0,b 0 o n 3 a,b 0,c 0 o n 2 依此類推eg 1 for...