c語言循環結構ppt
1. c語言 循環結構
#include<stdio.h>
main( )
{ int x,i,m;
do //當輸入的數大於等於0,或者為-1時,把這個輸入的數A放入變數m中
scanf("%d",&x);
while (x<0 && x!=-1);
m=x;
while (x!=-1) //輸入的數A不為-1時,再輸入一個數B
{ scanf("%d",&x);
if (x>0 && x>m) m=x; } //如果B>0並且B>A,那麼把B賦給A
if (m!=-1) printf("m=%d\n",m); //如果A不等於-1,那麼輸出A
}
======================================================
這個程序其實就是找最大的非負數,把第一個循環把負數過濾掉,把-1設置例外,因為-1被設置為結束第二個循環的條件
2. C語言:循環結構(排列組合)
#include<stdio.h>
int main()
{
int n;
scanf("%d",&n);
for (int i=n;i<=n+3;i++)
{
for (int j=n;j<=n+3;j++)
{
if(i==j) continue;
for (int k=n;k<=n+3;k++)
{
if(i==k||j==k) continue;
printf("%d%d%d ",i,j,k);
}
}
}
printf("\n");
return 0;
}
3. C語言三種循環結構的完整句子
for語句循環
1 for語句一般形式中的各表達式可以省略,但是分號間隔符不能少。需要注意省略表達式1之前要給循環變數賦初值。
2 如省略去表達式2或者3則將造成無限循環,這是應在循環體內設法結束循環
main(){
int a=0,n=4;
for(;;)(
a++,n--;
print("%d",a*2);
if(n==0) break;)
}
上面例子中 for語句的表達式完全省去,由循環體中的語句實現循環變數的遞減和循環條件的判斷。當n的值為0時,由break 語句終止循環,轉去執行for語句以後的程序。
在此情況下,for語句以等價於while(1)語句,如果在循環體中沒有相應的控制手段,將造成死循環
二 while 語句循環
1while語句中的表達式一般是關系表達式或者是邏輯表達式,只要表達式的值為真(非0)即可繼續循環
2 循環體中如果包括一個以上的語句 則必須用{}括起來,組成符合語句
3 應注意循環條件的選擇 以避免死循環
4 允許while語句的循環體又是while語句,從而形成雙循環。
三 do-while語句
1 do-while語句和while語句的區別在於 do-while語句是先執行後判斷,因此 do-while至少要執行一次循環體,而while是先判斷後執行,如果條件不滿足,則一次循環體語句也不執行。while語句和 do-while語句一般可以相互改寫。
2 在if語句和while語句中,表達式後面不能加分號,而在 do-while語句的表達式後面必須加分號。
3 do-while語句也可以組成多重循環,而且可以和while語句相互嵌套。在do和while之間的循環體由多個語句組成是,也必須用{}括起來形成一個復合語句
4. c語言循環結構
選D
第一次運行循環體:當x=3時,因為x滿足x小於6的條件,所以第一次運行循環體,余數為1,執行"**%d",此時輸出結果為**3.
註:(x%2)?"**%d":"##%d\n" 這是個條件表達式,其形式為:
表達式1?表達式2:表達式3
當「表達式1」的值為真時,執行「表達式2」,否則執行「表達式3」。
第一次循環:x++後,x=4,因為x依然小於6,所以繼續執行循環體,此時x的值變為4,4除以2後,余數為0,所以結果為假,執行「表達式2」,固輸出##4 並且回車
第二次循環:和前次一樣,當x=5時,除以2餘數為1,即為真,執行「表達式1」
所以輸出結果為:**5。
沒有第三次循環了,因為x要一直小於6,所以當x=5的時候,循環就到頭了。
o(∩_∩)o...
5. c語言的循環結構!不懂請詳講!謝了
看了一下幾位仁兄的回答,都只是敷衍了事。
在循環中,你應該先了解while語句:
語句格式是:
while(條件) //條件一般是個表達式如:c<10;
{
循環語句;
}
下面舉個簡單的例子 比如設計一個1+2+3+···+100;的程序:
#include"stdio.h"
void main()
{
int i,sum;
i=1;
sum=0;
while(i<=100)
{
sum+=i;
i++;
}
printf("結果是:%d\n",sum);
}
了解了while後就不難了解for語句了;
for語句的一般結構如下:
for(初值;條件;初值的改變);
以上面的程序為例,for語句就是一種簡單的寫法:
#include"stdio.h"
void main()
{
int i,sum;
for(i=1,sum=0;i<=100;(sum+=i),i++);
printf("最終結果為:%d\n",sum);
}
這樣就使得程序變得高效有簡潔。
好了就簡單介紹到這里了,你以後還是多看看書,這樣才有所提高嘛。
6. C語言循環結構
不是C語言只有三種結構,是所有的語言都只存在這三種結構!
順序結構:代碼按照編碼順序執行。
選擇結構,雙稱分支結構,細分有單分支,雙分支與多分支。單分支只有if結構,還用來做判斷。雙分支一般指的是if...else結構。多分支一般指的是switch結構,當然多重的if...else也可以實現,同時還是類惟邏輯尺等等編程思想。
循環結構:就是特定條件下要重復執行的語句。一般有步長型for,當型while,直到型do...while(部分語言中是until),以及枚舉型foreach(部分語言中是for...in幾種。還有幾中特殊的直撞調用或間接調用兩種形式實現的循環,在部分語言中將其單發為遞歸結構,但大多數時間由於是函數或方法的調用實現的,不歸語言結構范疇,所以雖有遞歸結構,多數語言中還只認為存在三種基礎結構,而遞歸屬於調用層面的結構。所以在死循環時,除了檢查我們的循環結構之外,還要特別注意是不是存在的遞歸調用上的缺少遞歸條件。
7. C語言的三種循環結構為
三種循環結構:
(1) for:
for (循環控制變數初始化; 循環終止條件; 循環控制變數增量)
{
循環體
}
循環執行步驟:第一,先進行循環控制變數初始化;
第二,執行循環終止條件,如果判斷結果為真,則進入第三步;如果為假則循環終止並退出;
第三,執行循環體;
第四,執行循環控制變數增量,轉入第二步;
註:for循環()中的三部分除了循環終止條件外,其他兩部分都可以省略,但標準的for循環中,應該把循環控制變數的初始化,增量都放在()當中,並且在循環體中絕對不應該更改循環控制變數;
(2) while:
循環控制變數初始化
while(循環終止條件)
{
循環體
循環控制變數增量
}
循環執行步驟:第一,先進行循環控制變數初始化(在while之前);
第二,判斷循環終止條件,如果判斷結果為真,則進入第三步;如果為假則不執行循環體;
第三,執行循環體;
第四,執行循環控制變數增量,轉入第二步;
(3) do while:
循環控制變數初始化
do
{
循環體
循環控制變數增量
}while (循環終止條件);
循環執行步驟:第一,先進行循環控制變數初始化(在do while之前);
第二,執行循環體;
第三,執行循環控制變數增量;
第四,判斷循環終止條件,如果判斷結果為真,則返回第二步;如果為假則直接退出循環;
8. C語言,循環結構
1.#include <stdio.h>
int main (void)
{
int m, n, p, tmp;
printf ("Please type in two number:\n");
scanf ("%i %i", &m, &n); //輸入兩個數,分別放入m, n
p=m*n; //先把兩數的積算出來,後面m和n的值會有變
while (n!=0){
tmp=m%n;
m=n;
n=tmp; //這段是求最大公約數的演算法
}
printf ("The GCD is %i\n", m); //上面的演算法n=0時m這時的值就是最大公約數
printf ("The LCM is %i\n", p/m);//兩數的積除以最大公約數就是最小公倍數了
return 0;
}
2.
#include <stdio.h>
#include <ctype.h>
#include <string.h>
int main()
{
int i;
unsigned letters = 0;
unsigned spaces = 0;
unsigned digits = 0;
unsigned others = 0;
char line[256];
printf("Enter a line of words: \n");
gets(line);
for(i = 0; i < strlen(line); ++i)
{
if(isalpha(line[i]))
++letters;
else if(isspace(line[i]))
++spaces;
else if(isdigit(line[i]))
++digits;
else
++others;
}
printf("The line you entered has:\n");
printf("%d letters\n", letters);
printf("%d spaces\n", spaces);
printf("%d digits\n", digits);
printf("%d others\n", others);
}
9. C語言 循環體結構 解釋 5
A中,對於int i=100;i=i%100+1;循環變數i的更新為i對100取余+1。任何整形對於N取余的結果都在[0,100)之間,就算+1,i也永遠不會大於100,故為死循環。
B.典型的死循環,沒有循環變數控制,循環體內部是空語句 只有一個空語句「 ; 」。這是一個不做任何操作的死循環。
C.這道題的bug恐怕就在選項C了。從出題人的意思來看,k初始值是1000。do while的特點是每做一遍循環體中的內容{++k;},然後再檢查循環條件(k>=1000)。循環體++k第一次運行之後,k已經大於1000了,滿足循環繼續下去的條件。所以出題人認為,在後續的循環過程中,k不斷的自增,k永遠不會小於1000。所以出題人認為這個也是個死循環。
D.s被初始化為36,每次循環都執行一次--s,s的內容會自減1.while(s)的意思就是當s非零的時候,執行循環體。s是每次循環自減的,從36開始自減,執行36次之後,s就為0了,不再滿足循環條件。於是循環是可以結束的,不是死循環。
註:
1.while(exp){stat;}
a)檢查exp的值
b)當表達式exp為非零值, 執行循環體中的語句stat,並回到a);當表達式exp的值為0,終止循環 。
2.do{stat;}while(exp);
a)執行循環體語句stat,然後檢查exp的值;
b)如果exp的值非零,則回到a)繼續循環;如果exp為零,終止循環
3.for(exp1; exp2;exp3){stat;}
a)循環體第一執行前,先執行exp1;
b)檢查exp2的值,如果exp2非零做c);如果exp2為零,終止循環;
c)執行循環體中的stat語句,然後執行exp3,再回到b)
p.s.這個出題人在題中的選項C翻了一個錯誤,其實有符號的整形int在自增到int能表示的正最大值之後繼續自增會變成int能表示的負最小值。這種行為叫做int的溢出。所以k會在自增的過程中突然變成負值,小於1000了,循環會終止。但終止的原因如我所述,而不是邏輯上期待的終止方式。詳細的情況,感興趣的話去翻翻書或者問問老師,問我也可以……
10. 哪能找到石油大學 曾怡教授C語言的ppt 好心人發到這個郵箱[email protected],加分
油大學曾怡副教授的C語言視頻講座,和譚浩強寫的《C程序設計》教的一樣。
簡介:
C程序設計視頻教程(曾怡):本套視頻教程由曾怡副教授講解,使用教材為:《C程序設計》 譚浩強 清華大學出版社出版。是難得的C語言學習視頻教程。全程共30講,每講45分鍾左右,CSF視頻格式。講課內容如下:
第一講 第一章 C語言概述
第二講 第二章 程序的靈魂—演算法
第三講 第三章 數據類型、運算符與表達式
第四講 第三章 數據類型、運算符與表達式
第五講 第三章 數據類型、運算符與表達式
第六講 第三章 數據類型、運算符與表達式
第四章 最簡單的C程序設計—順序程序設計
第七講 第四章 最簡單的C程序設計—順序程序設計
第八講 第四章 最簡單的C程序設計—順序程序設計
第九講 第五章 選擇結構的程序設計
第十講 第五章 選擇結構的程序設計
第十一講 第五章 選擇結構的程序設計
第十二講 第六章 循環結構程序設計
第十三講 第六章 循環結構程序設計
第十四講 第六章 循環結構程序設計
第十五講 第六章 循環結構程序設計
第七章 數組
第十六講 第七章 數組
第十七講 第七章 數組
第十八講 第七章 數組
第十九講 第七章 數組
第二十講 第七章 數組
第八章 函數
第二十一講 第八章 函數
第二十二講 第八章 函數
第二十三講 第八章 函數
第二十四講 第十章 指針
第二十五講 第十章 指針
第二十六講 第十章 指針
第二十七講 第十章 指針
第十一章 結構體
第二十八講 第十一章 結構體
復習總結第一講
復習總結第二講