1. <rp id="zsypk"></rp>

      2. do語句改寫為while語句

        時間:2021-08-12 13:40:34 改寫 我要投稿

        關(guān)于do語句改寫為while語句

          do語句能夠改寫為while語句

          C語言while、do-while、for循環(huán)課程5

          課程3中,提到C語言基本語句分為:數(shù)據(jù)定義語句,數(shù)據(jù)處理語句

          數(shù)據(jù)處理語句又可分為:表達(dá)式語句,函數(shù)調(diào)用語句,空語句(;),復(fù)合語句,流程控制語句。

          流程控制:指程序代碼執(zhí)行的順序。流程的分類:順序、選擇、循環(huán)。

          C語言的循環(huán)結(jié)構(gòu)通過三種語句來實現(xiàn),即while、do-while、forWhile語句的一般形式while(循環(huán)條件表達(dá)式)循環(huán)體語句;

          功能:當(dāng)循環(huán)條件表達(dá)式為真,執(zhí)行循環(huán)體語句,執(zhí)行完了,再判斷條件表達(dá)式是否為真,為真,則再執(zhí)行,直到條件表達(dá)式為假時,退出while循環(huán)。

          實例1:用while語句求1~100的累加和。

          #include//C語言編譯預(yù)處理命令,文件包含為stdio.h

          voidmain()//至少有一個用main()命名的主函數(shù),返回值為void無值類型{

          inti=1,sum=0;/*初始化循環(huán),定義變量i和累加器sum,定義和之前,累加器清零*/

          while(i<=100)

          {

          sum+=i;//sum+=i是一個復(fù)合賦值運(yùn)算符,等價于sun=sun+i;i++;

          }

          printf("1+2+3+...+100=%d ",sum);//輸出十進(jìn)制數(shù),1加到100累加器的和}

          MicrosoftVisualC++6.0運(yùn)行結(jié)果

          使用while循環(huán)時,一定要對循環(huán)條件表達(dá)式中出現(xiàn)的變量提前賦值,并在循環(huán)體內(nèi)修改有關(guān)變量的值,以使循環(huán)能趨于終止。

          While循環(huán)為當(dāng)型循環(huán),do-while循環(huán)也叫直到型循環(huán)。

          do-while語句的一般形式為:

          do

          {

          循環(huán)體語句}while(

          循環(huán)條件表達(dá)式

          )

          實例2:用do-while編制一個求n!的程序,n的值由鍵盤輸入。

          #include

          voidmain()

          {inti=1,n,p=1;

          printf("請從鍵盤輸入一個數(shù),進(jìn)行連乘積: ");

          scanf("%d",&n);

          do

          {p=p*i;

          i++;

          }while(i<=n);

          printf("連乘積的結(jié)果為p=n!:%d ",p);

          }

          分析:此程序,先定義三個變量i、n、p,p從p乘1開始執(zhí)行,再i進(jìn)行自增1,循環(huán)體中的語句執(zhí)行完畢后,判斷while的循環(huán)條件表達(dá)式,當(dāng)i自增1為2時,看2是否<=輸入的n值,若為真,則繼續(xù)返回do循環(huán),直到i自增的值比n大,則退出循環(huán)。

          do-while主要用于人機(jī)交互,do-while循環(huán)是先執(zhí)行后判斷,do里面的循環(huán)體至少被執(zhí)行一次。區(qū)別于while是先判斷循環(huán)條件表達(dá)式,后執(zhí)行。

          for循環(huán)也叫步長型循環(huán)

          一般格式:for(表達(dá)式1;表達(dá)式2;表達(dá)式3)循環(huán)體語句;

          功能:先執(zhí)行表達(dá)式1,再執(zhí)行表達(dá)式2,如果表達(dá)式2的值為真,就執(zhí)行循環(huán)體語句,最后執(zhí)行表達(dá)式3.完成一次循環(huán)后,從表達(dá)式2執(zhí)行,直到表達(dá)式2為假,退出循環(huán)。

          實例3:參考實例1,用while求1~100的累加和,現(xiàn)在用for語句求1~100的累

          加和。

          #include

          intmain(void)

          {

          inti;intsum=0;

          /*初始化循環(huán),定義變量i

          和累加器sum,定義和之前,累加器清零*/

          for(i=1;i<=100;i++)

          {

          sum=sum+i;

          }

          printf("sum=%d ",sum);

          return0;

          }

          實例4:愛因斯坦的階梯問題:有一個長階梯,若每步上2階,最后剩1階;若每步上3階,最后剩2階;若每步上5階,最后剩4階;若每步上6階,最后剩5階;只有每步上7階,最后剛好一階也不剩。請問該階梯至少有多少階。編寫一個C程序解決該問題。

          #include

          main()

          {intx;

          for(x=7;;x+=7)

          if(x%3==2&&x%5==4&&x%6==5)

          break;

          printf("Thenumberoftheladdersis:%d ",x);

          }

          分析:發(fā)現(xiàn)x一定是7的整數(shù)倍,可以依次遞增地求出7的整數(shù)倍的值(7*1、7*2、7*3……),每求出一值,就用該值與2、3、5、6進(jìn)行取模運(yùn)算,最先得到的滿足上述5個方程式的x值即為本題的答案。

          用while語句,簡單快速實現(xiàn)愛因斯坦的階梯問題

          #include

          intmain()

          {

          inti=1;/*i為所設(shè)的階梯數(shù)*/

          while(!((i%2==1)&&(i%3==2)&&(i%5==4)&&(i%6==5)&&(i%7==0)))

          ++i;/*滿足一組同余式的判別*/

        【do語句改寫為while語句】相關(guān)文章:

        do語句能夠改寫為語句練習(xí)03-31

        關(guān)于改寫語句匯總03-30

        英語句型改寫規(guī)則與練習(xí)04-01

        改寫擬人句練習(xí)語句08-19

        高二英語句子改寫復(fù)習(xí)題目及答案03-20

        牧童為學(xué)改寫07-11

        改寫《木蘭詩》為小說01-06

        改寫古詩《浣溪沙》為作文07-17

        改寫天凈沙秋思為作文08-15

        99热这里只有精品国产7_欧美色欲色综合色欲久久_中文字幕无码精品亚洲资源网久久_91热久久免费频精品无码
          1. <rp id="zsypk"></rp>