下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
第C++用函數(shù)對算法性能進行測試目錄前言工具模板說明測試
前言
Algorithm+DataStructures=Programs瑞士計算機科學(xué)家尼古拉斯沃斯
工具
C/C++庫函數(shù)中的time.h/ctime庫中的clock()函數(shù)
模板
usingnamespacestd;
clock_tstart_time=clock();
{算法代碼塊};
clock_tend_time=clock();
cout(double)(end_time-start_time)/CLOCKS_PER_SEC秒
說明
clock()函數(shù)返回類型為clock_t(實際上是long類型),它返回從開啟某個程序進程到再次調(diào)用clock()函數(shù)之間的CPU時鐘計時單元(時鐘周期)。
CLOCKS_PER_SEC是標準庫中所定義的宏,表示每1秒CPU時鐘計時單元(時鐘周期)的個數(shù)
end_time-start_time表示該程序執(zhí)行期間CPU時鐘計時單元(時鐘周期)的總個數(shù),除以每秒鐘CPU時鐘計時單元(時鐘周期),即可得到程序?qū)嶋H運行時間,返回的單位是毫秒。
測試
分別測試選擇排序算法和C++中的sort()函數(shù)的算法性能,測試數(shù)據(jù)由隨機數(shù)生成。
#includeiostream
#includealgorithm
#includectime
usingnamespacestd;
//選擇排序
voidSelectSort(inta[],intn){
for(inti=0;ii++){
intmin_index=i;
for(intj=i+1;jj++)
if(a[j]a[min_index])
min_index=j;
swap(a[i],a[min_index]);
//隨機數(shù)組
int*RandomArray(intn,intrangeL,intrangeR){
int*arr=newint[n];//創(chuàng)建一個大小為n的數(shù)組
srand(time(NULL));//以時間為"種子"產(chǎn)生隨機數(shù)
for(inti=0;ii++){
arr[i]=rand()%(rangeR-rangeL+1)+rangeL;//生成指定區(qū)間[rangeL,rangeR]里的數(shù)
returnarr;
intmain(){
intn;
cout"請輸入數(shù)據(jù)規(guī)模n:";cinn;
int*arr1,*arr2;
arr1=RandomArray(n,0,10000);
arr2=arr1;
clock_tstart_time1=clock();
SelectSort(arr1,n);//選擇排序算法
clock_tend_time1=clock();
cout"選擇排序耗時:"(double)(end_time1-start_time1)/CLOCKS_PER_SEC"秒"endl;
clock_tstart_time2=clock();
sort(arr2,arr2+n);//C++中sort()排序函數(shù),底層為優(yōu)化的快速排序算法
clock_tend_time2=clock();
cout"優(yōu)化快排耗時:"(double)(end_time2-start_time2)/CLOCKS_PER_SEC"秒"endl;
return0;
}
測試結(jié)果
測試結(jié)果分析
通過對比可知,在數(shù)據(jù)規(guī)模相同的情況下,C++sort()排序算法的性能遠遠遠遠優(yōu)于選擇排序。
我們能從數(shù)據(jù)上直觀的看到數(shù)據(jù)規(guī)模的增長所帶來的運行時間的加長,數(shù)據(jù)規(guī)模由10000變?yōu)?00000,擴大了10倍,那么根據(jù)時間復(fù)雜度的分析,選擇排序的算法時間會擴大100倍左右,而sort()排序函數(shù)則會擴大10倍左右,由測試結(jié)果看出,確實如此。
因為選擇排序算法的時間復(fù)雜度為O(n^2),而C++sort()排序函數(shù)的底層實現(xiàn)原理是快速排序算法,而且是優(yōu)化的快速排序,系統(tǒng)會根據(jù)數(shù)據(jù)形式和數(shù)據(jù)量自動選擇合適的排序方法。它每次排序中不只選擇一種方法,比如給一個數(shù)據(jù)量較大的數(shù)組排序,開始采用快速排序,
溫馨提示
- 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)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 可穿戴設(shè)備市場發(fā)展趨勢分析
- 2026年物流管理專業(yè)學(xué)生實踐考試題物流規(guī)劃與優(yōu)化案例分析題
- 2026年工業(yè)自動化系統(tǒng)調(diào)試模擬題
- 2026年銀行職員招聘考試金融知識會計實務(wù)模擬試題
- 2026年電子商務(wù)營銷專家網(wǎng)絡(luò)營銷策略分析與實施模擬試題及答案
- 2026年電氣工程師專業(yè)招聘筆試題庫大全
- 2026年大學(xué)入學(xué)考試英語筆試模擬題
- 2026年會計師中級職稱考試核心題目與詳解
- 2026年注冊會計師財務(wù)成本管理預(yù)測模擬試題
- 2026年能源行業(yè)面試問題及答案參考
- 水產(chǎn)養(yǎng)殖技術(shù)手冊
- 英國汽車工業(yè)市場分析現(xiàn)狀供需格局投資前景未來規(guī)劃研究報告
- 2025年及未來5年市場數(shù)據(jù)中國吸塑、注塑行業(yè)發(fā)展前景預(yù)測及投資戰(zhàn)略數(shù)據(jù)分析研究報告
- 眼科醫(yī)療風(fēng)險防范培訓(xùn)
- 物流金融理論與實務(wù)課件
- 海內(nèi)外云廠商發(fā)展與現(xiàn)狀(三):資本開支壓力與海外云廠需求情況拆解-國信證券
- 2025年社區(qū)網(wǎng)格員招錄考試真題庫(含答案)
- GB/T 46510-2025玩具水基材料中游離甲醛的測定高效液相色譜法
- 溴化鋰清洗施工方案
- 第四方支付業(yè)務(wù)合規(guī)指引
- 手勢舞基本功課件
評論
0/150
提交評論