溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

C++/ C循環(huán)語句的效率問題

發(fā)布時(shí)間:2020-07-08 08:13:23 來源:網(wǎng)絡(luò) 閱讀:1264 作者:巖梟 欄目:編程語言


循環(huán)語句的效率:

C++/ C 循環(huán)語句中,f or語句使用頻率最高,whi l e語句其次,do語句很少用。提高循環(huán)體效率的基本辦法是降低循環(huán)體的復(fù)雜性。

1.在多重循環(huán)中,如果有可能,應(yīng)當(dāng)將最長的循環(huán)放在最內(nèi)層,最短的循環(huán)放在最外層,以減少CPU跨切循環(huán)層的次數(shù)。

1

程序1

for (row = 0; row<100; row++)

{

for (col = 0; col<5; col++)

{

sum = sum + a[row][col];

}

}

程序2:

for (col = 0; col<5; col++)

{

for (row = 0; row<100; row++)

{

sum = sum + a[row][col];

}

}

分析:程序1低效率,長循環(huán)在最外層;程序2高效率,長循環(huán)在最內(nèi)層。

2.如果循環(huán)體內(nèi)存在邏輯判斷,并且循環(huán)次數(shù)很大,宜將邏輯判斷移到循環(huán)體的外面。

程序1

for (i = 0; i <N; i++)

{

if (condition)

{

DoSomething();

}

else

{

DoOtherthing();

}

}

程序2:

if (condition)

{

for (i = 0; i < N; i++)

{

DoSomething();

}

}

else

{

for (i = 0; i < N; i++)

{

DoOtherthing();

}

}


分析:程序1效率低但程序簡潔;程序2效率高但程序不簡潔.

補(bǔ)充:

goto語句:能夠從多重循環(huán)體中咻地一下子跳到外面,用不著寫很多次的break語句;由于goto語句存在很多隱患,因此主張少用、慎用goto 語句。

如:

{

{

{

goto error;

}

}

}

error;


 


向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI