您好,登錄后才能下訂單哦!
循環(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;
免責(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)容。