欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言詳細(xì)講解循環(huán)語句的妙用

 更新時(shí)間:2022年04月20日 17:01:34   作者:清風(fēng)自在?流水潺潺  
C語言循環(huán)控制語句是一個(gè)基于C語言的編程語句,該語句主要有while循環(huán)語句、do-while循環(huán)語句和for循環(huán)語句來實(shí)現(xiàn)循環(huán)結(jié)構(gòu),在循環(huán)過程中還有關(guān)鍵字break、continue、do、break控制中斷繼續(xù)與結(jié)束等操作

一、循環(huán)語句分析

循環(huán)語句的基本工作方式

  • 通過條件表達(dá)式判定是否執(zhí)行循環(huán)體
  • 條件表達(dá)式遵循 if 語句表達(dá)式的原則

do,while,for的區(qū)別

  • do 語句先執(zhí)行后判斷,循環(huán)體至少執(zhí)行一次
  • while 語句先判斷后執(zhí)行,循環(huán)體可能不執(zhí)行
  • for 語句先判斷后執(zhí)行,相比 while 更簡(jiǎn)潔

二、do ... while 語句的循環(huán)方式

三、while 語句的循環(huán)方式

四、for 語句的循環(huán)方式

下面看一段三種循環(huán)語句使用對(duì)比的代碼:

#include <stdio.h>
 
int f1(int n)
{
    int ret = 0;
    
    if( n > 0 )
    {
        do
        {
            ret += n;
            n--;
        }
        while( n > 0 );
    }
    
    return ret;
}
 
int f2(int n)
{
    int ret = 0;
    
    while( n > 0 )
    {
        ret += n;
        n--;
    }
    
    return ret;
}
 
int f3(int n)
{
    int ret = 0;
    int i = 0;
    
    for(i=1; i<=n; i++)
    {
        ret += i;
    }
    
    return ret;
}
 
int main()
{
    printf("%d\n", f1(100));
    printf("%d\n", f2(100));
    printf("%d\n", f3(100));
    
    return 0;
}

下面為輸出結(jié)果:

五、break和 continue 的區(qū)別

  • break 表示終止循環(huán)的執(zhí)行
  • continue 表示終止本次循環(huán),進(jìn)入下次循環(huán)執(zhí)行

下面看一段 continue 和 break 的區(qū)別代碼:

#include <stdio.h>
 
void f1(int n)
{
    int i = 0;
    
    for(i=1; i<=n; i++)
    {
        if( (i % 2) == 0 )
        {
            break;
        }
        
        printf("%d ", i);
    }
    
    printf("\n");
}
 
void f2(int n)
{
    int i = 0;
    
    for(i=1; i<=n; i++)
    {
        if( (i % 2) == 0 )
        {
            continue;
        }
        
        printf("%d ", i);
    }
    
    printf("\n");
}
 
int main()
{
    f1(10);
    f2(10);
    
    return 0;
}

下面為輸出結(jié)果:

六、do 和 break 的妙用

#include <stdio.h>
#include <malloc.h>
 
int func(int n)
{
    int i = 0;
    int ret = 0;
    int* p = (int*)malloc(sizeof(int) * n);
    
    do
    {
        if( NULL == p ) break;
        
        if( n < 5 ) break;
 
        if( n > 100) break;
        
        for(i=0; i<n; i++)
        {
            p[i] = i;
            printf("%d\n", p[i]);
        }
        
        ret = 1;
    }while( 0 );
    
    printf("free(p)\n");
    
    free(p);
    
    return ret;
}
 
int main()
{
    if( func(10) )
    {
        printf("OK\n");
    }
    else
    {
        printf("ERROR\n");
    }
 
    return 0;
}

下面為輸出結(jié)果:

注意 do{ } while(0)是只執(zhí)行一次循環(huán)體。

如果采用下面這種寫法:

#include <stdio.h>
#include <malloc.h>
 
int func(int n)
{
    int i = 0;
    int ret = 0;
    int* p = (int*)malloc(sizeof(int) * n);
    
    if( NULL == p ) return ret;
        
    if( n < 5 ) return ret;
 
    if( n > 100) return ret;
        
    for(i=0; i<n; i++)
    {
        p[i] = i;
        printf("%d\n", p[i]);
    }
        
    ret = 1;
    
    printf("free(p)\n");
    
    free(p);
    
    return ret;
}
 
int main()
{
    if( func(4) )
    {
        printf("OK\n");
    }
    else
    {
        printf("ERROR\n");
    }
 
    return 0;
}

可以看到程序并沒有輸出 free(p),也就是說申請(qǐng)的內(nèi)存并沒有得到釋放,造成內(nèi)存泄漏。

所以說do 和 break 一起妙用,可以暴力跳出當(dāng)前循環(huán),避免內(nèi)存泄漏。

七、小結(jié)

  • for 循環(huán)先進(jìn)行判斷再進(jìn)入循環(huán)體
  • for 循環(huán)適合于循環(huán)次數(shù)固定的場(chǎng)合
  • while 循環(huán)先進(jìn)行判斷再進(jìn)入循環(huán)體執(zhí)行
  • while 循環(huán)適合于循環(huán)次數(shù)不定的場(chǎng)合
  • do ... while 循環(huán)先執(zhí)行循環(huán)體再進(jìn)行條件判斷
  • do ... while 循環(huán)至少執(zhí)行一次循環(huán)體

到此這篇關(guān)于C語言詳細(xì)講解循環(huán)語句的妙用的文章就介紹到這了,更多相關(guān)C語言循環(huán)語句內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語言對(duì)冒泡排序進(jìn)行升級(jí)介紹

    C語言對(duì)冒泡排序進(jìn)行升級(jí)介紹

    大家好,本篇文章主要講的是C語言對(duì)冒泡排序進(jìn)行升級(jí)介紹,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下
    2022-01-01
  • C++ OpenCV實(shí)戰(zhàn)之文檔照片轉(zhuǎn)換成掃描文件

    C++ OpenCV實(shí)戰(zhàn)之文檔照片轉(zhuǎn)換成掃描文件

    這篇文章主要為大家介紹一個(gè)C++?OpenCV的實(shí)戰(zhàn)——文檔照片轉(zhuǎn)換成掃描文件,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2022-09-09
  • C++哈希應(yīng)用之位圖,哈希切分與布隆過濾器詳解

    C++哈希應(yīng)用之位圖,哈希切分與布隆過濾器詳解

    這篇文章主要為大家詳細(xì)介紹了C++哈希應(yīng)用中的位圖、哈希切分與布隆過濾器,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,需要的可以參考一下
    2023-04-04
  • C++?TCP網(wǎng)絡(luò)編程詳細(xì)講解

    C++?TCP網(wǎng)絡(luò)編程詳細(xì)講解

    TCP/IP是一種面向連接的、可靠的、基于字節(jié)流的傳輸層通信協(xié)議,它會(huì)保證數(shù)據(jù)不丟包、不亂序。TCP全名是Transmission?Control?Protocol,它是位于網(wǎng)絡(luò)OSI模型中的第四層
    2022-09-09
  • 詳細(xì)分析C++ 多態(tài)和虛函數(shù)

    詳細(xì)分析C++ 多態(tài)和虛函數(shù)

    這篇文章主要介紹了C++ 多態(tài)和虛函數(shù)的相關(guān)資料,文中示例代碼非常詳細(xì),幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • C語言排序算法之桶排序解析

    C語言排序算法之桶排序解析

    這篇文章主要介紹了C語言排序算法之桶排序解析,桶排序Bucket?sort或所謂的箱排序,是一個(gè)排序算法,工作的原理是將數(shù)組分到有限數(shù)量的桶里,每個(gè)桶再分別排序,大部分是在分桶時(shí),即插入時(shí)就排序了,需要的朋友可以參考下
    2023-10-10
  • C++類與對(duì)象深入之運(yùn)算符重載與const及初始化列表詳解

    C++類與對(duì)象深入之運(yùn)算符重載與const及初始化列表詳解

    運(yùn)算符是程序中最最常見的操作,例如對(duì)于內(nèi)置類型的賦值我們直接使用=賦值即可,因?yàn)檫@些編譯器已經(jīng)幫我們做好了,但是對(duì)象的賦值呢?能直接賦值嗎
    2022-06-06
  • C語言深入探究水仙花數(shù)與變種水仙花數(shù)代碼

    C語言深入探究水仙花數(shù)與變種水仙花數(shù)代碼

    求水仙花數(shù)和變種水仙花數(shù)是非常適合初學(xué)者學(xué)習(xí)的代碼,其中包含的循環(huán)和邏輯方式等知識(shí)點(diǎn)。這既能起到對(duì)以往知識(shí)的復(fù)習(xí),也可以學(xué)習(xí)到一種不同的邏輯思考方式
    2022-05-05
  • C語言利用面試真題理解指針的使用

    C語言利用面試真題理解指針的使用

    C語言這門課程在計(jì)算機(jī)的基礎(chǔ)教學(xué)中一直占有比較重要的地位,然而要想突破C語言的學(xué)習(xí),對(duì)指針的掌握是非常重要的,本文將具體針對(duì)指針的基礎(chǔ)做詳盡的介紹
    2022-08-08
  • C++實(shí)現(xiàn)冒泡排序(BubbleSort)

    C++實(shí)現(xiàn)冒泡排序(BubbleSort)

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)冒泡排序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-04-04

最新評(píng)論