問題:
/*
*檔名稱:複雜度.cpp
*作 者:陳迪
*完成日期:2023年9月6日
*版 本 號:v1.0
* *問題描述:排序是電腦科學中的乙個基本問題,產生了很多種適合不同情況下適
用的演算法,也一直作為演算法研究的熱點。本專案提供兩種排序演算法,復
雜度為o(n 2)的選擇排序selectsort,和複雜度為o(nlogn)的快速排序
quicksort,在main函式中加入了對執行時間的統計。
*輸入描述:大資料檔案
*程式輸出:執行時間
*/
程式一**:
#include #include #include #define maxnum 100000
void selectsort(int a, int n)
if(k != j)
}}int main()
while(fscanf(fp, "%d", &x[n])!=eof)
n++;
printf("資料量:%d, 開始排序....", n);
t1=time(0);
selectsort(x, n);
t2=time(0);
printf("用時 %d 秒!", (int)(t2-t1));
fclose(fp);
return 0;
}
執行結果:
程式二**:
#include #include #include #define maxnum 100000
void quicksort(int data,int first,int last)
{ int i, j, t, base;
if (first>last)
return;
base=data[first];
i=first;
j=last;
while(i!=j)
{while(data[j]>=base && i
執行結果:
從這兩個程式執行時間來看,第二個程式是瞬間完成,而第乙個程式則需要一段時間。從這兩個程式複雜度來看,第乙個複雜度是n的平方,第二個是o(n
logn
)n*log(n),顯然第乙個複雜度是指數型增長,第二個則是線性增長,故執行時間第二個較第乙個快。
知識點總結:
這個程式主要考察了我們對程式時間複雜度的理解,以便我們今後的程式設計中注意複雜度對程式執行時間的影響。
學習心得:
通過程式的執行直觀的理解了複雜度對程式執行的時間影響是多麼的重要,也明白了複雜度對以後程式設計的意義重大。
(第二週專案3)體驗複雜度
1 兩種排序演算法的執行時間 提供兩種排序演算法,複雜度為o n 2 的選擇排序selectsort,和複雜度為o nlogn 的快速排序quicksort,在main函式中加入了對執行時間的統計。利用乙個將近10萬條資料的檔案作為輸入資料執行程式,感受兩種演算法在執行時間上的差異。執行中需要的資料...
第二週 專案3 體驗複雜度
include include include define maxnum 100000 void selectsort int a,int n if k j int main while fscanf fp,d x n eof n printf 資料量 d,開始排序.n t1 time 0 sel...
第二週專案3 體驗複雜度
檔名稱 專案3體驗複雜度.cpp 作 者 林穎 完成日期 2015年9月11日 問題描述 排序是電腦科學中的乙個基本問題,產生了很多種適合不同情況下適用的演算法,也一直作為演算法研究的熱點。本專案提供兩種排序演算法,複雜度為o n2 的選擇排序selectsort,和複雜度為o nlogn 的快速排...