1. 程式人生 > 其它 >【C語言】第5章 迴圈結構程式設計

【C語言】第5章 迴圈結構程式設計

第5章 迴圈結構程式設計

三種基本迴圈控制結構

使用while語句實現迴圈
先判斷條件表示式,後執行迴圈體語句

while (迴圈條件表示式)
{ 
    迴圈體
}

用do-while語句實現迴圈
先無條件地執行迴圈體,然後判斷迴圈條件是否成立

do
{
   語句;
}
  while(表示式);

用for語句實現迴圈

for語句的執行過程:
(1) 先求解表示式1
(2) 求解表示式2,若其值為真,執行迴圈體,然後執行下面第(3)步。若為假,則結束迴圈,轉到第(5)步
(3) 求解表示式3
(4) 轉回上面步驟(2)繼續執行
(5) 迴圈結束,執行for語句下面的一個語句

for(初始條件;迴圈條件表示式;迴圈的調整器)
	語句;
迴圈的巢狀

(1) 一般情況下,3種迴圈可以互相代替
(2) 在while和do–while迴圈中,迴圈體應包含使迴圈趨於結束的語句。
(3) 用while和do–while迴圈時,迴圈變數初始化的操作應在while和do–while語句之前完成。而for語句可以在表示式1中實現迴圈變數的初始化。

改變迴圈執行的狀態

用break語句提前終止迴圈
用continue語句提前結束本次迴圈

break語句和continue語句的區別
continue語句只結束本次迴圈,而不是終止整個迴圈的執行
break語句結束整個迴圈過程,不再判斷執行迴圈的條件是否成立

迴圈程式舉例
求Π的近似值
#include <stdio.h>
#include <math.h>
int main()
{  int sign=1; double pi=0,n=1,term=1;
    while(fabs(term)>=1e-6) 
    {  pi=pi+term;
        n=n+2; 
        sign=-sign; 
        term=sign/n;    
     }
    pi=pi*4;          
    printf("pi=%10.8f\n",pi);  
    return 0;
}
求斐波那契數列的前40個數
#include <stdio.h>
int main()
 {  int f1=1,f2=1,f3;  int i;
    printf("%12d\n%12d\n",f1,f2);
    for(i=1; i<=38; i++)
    {  f3=f1+f2;
       printf("%12d\n",f3);
       f1=f2;
       f2=f3;
    }
    return 0;
}
輸入一個大於3的整數n,判斷它是否是素數(質數)
#include<studio.h>
int main(){
int n,i;
print("n=?");scanf("%d",&n);
for(i=2;i<=n-1;i++)
	if(n%i==0)break;
if(i<n)printf("%d is not\n",n);
else printf("%d is \n",n);
return 0;
}
譯密碼。為使電文保密,往往按一定規律將其轉換成密碼,收報人再按約定的規律將其譯回原文。(改變為其後第4個字母)
char c;
c=getchar();                                         
while(c!=‘\n’)   
{  if((c>=‘a’ && c<=‘z’) || (c>=‘A’ && c<=‘Z’)) 
     {  if(c>='W' && c<='Z' || c>='w' && c<='z') 
            c=c-22;   
        else  c=c+4;   
     }
     printf("%c",c);                                 
     c=getchar(); 
}

程式改進
char c;
while((c=getchar())!=‘\n’)   
{  if((c>=‘A’ && c<=‘Z’) || (c>=‘a’ && c<=‘z’)) 
   {  c=c+4;         
      if(c>=‘Z’ && c<=‘Z’+4 || c>‘z’) 
          c=c-26;         
   }
   printf("%c",c);          
}