C語言初級有以下程式段輸出結果是

2021-06-17 08:04:55 字數 3496 閱讀 7483

1樓:

for(i=1;i<=15;j+=4)一定是給錯了,應該是for(i=1;i<=15;i+=4),取4個值1,5,9,13;

for(j=3;j<=19;j+=4) m++會執行5次m++,也就是m+5,j分別取3,7,11,15,19;

兩個迴圈是巢狀關係,合計執行為4*5=20。

2樓:匿名使用者

外層迴圈應該是

for(i=1;i<=15;i+=4)

i=1(i<=15成立):

j=3(j<=19成立): m++;(此時m=1)j=7(j<=19成立):m++;(此時m=2)j=11(j<=19成立):

m++;(此時m=3)j=15(j<=19成立):m++;(此時m=4)j=19(j<=19成立):m++;(此時m=5)j=23(j<=19不成立):

內層迴圈結束i=5(i<=15成立):

j=3(j<=19成立): m++;(此時m=6)j=7(j<=19成立):m++;(此時m=7)j=11(j<=19成立):

m++;(此時m=8)j=15(j<=19成立):m++;(此時m=9)j=19(j<=19成立):m++;(此時m=10)j=23(j<=19不成立):

內層迴圈結束i=9(i<=15成立):

j=3(j<=19成立): m++;(此時m=11)j=7(j<=19成立):m++;(此時m=12)j=11(j<=19成立):

m++;(此時m=13)j=15(j<=19成立):m++;(此時m=14)j=19(j<=19成立):m++;(此時m=15)j=23(j<=19不成立):

內層迴圈結束i=13(i<=15成立):

j=3(j<=19成立): m++;(此時m=16)j=7(j<=19成立):m++;(此時m=17)j=11(j<=19成立):

m++;(此時m=18)j=15(j<=19成立):m++;(此時m=19)j=19(j<=19成立):m++;(此時m=20)j=23(j<=19不成立):

內層迴圈結束i=17(i<=15不成立):外層迴圈結束所以雙重迴圈結束,輸出m的值為20。

從上面的分析可以看出,外層迴圈每執行1次,內層迴圈執行5次(即m累加5次)。外層迴圈一共執行4次,所以m的值20

3樓:匿名使用者

不對啊。第一個for迴圈的應該是i+=4

這樣外層迴圈4次 內層迴圈5次 m=20.。。。

4樓:

裡面的for迴圈執行5次,外面的執行4次,4*5即20

c語言 以下程式段的輸出結果是多少

5樓:xu水冰淼

printf輸出:bai110

第一括號du:1;zhi

第二括號:5

第三括號:5

第四括號:5

最後的三dao個括號填的內

值是有歧義的,容比如要是隻是那個條件,然後分別問:

int a[4]=,*p;p=a;此時*p的值是(      )int a[4]=,*p;p=a;此時*p++的值是(      )int a[4]=,*p;p=a;此時(*p)++的值是(      )

就應該是樓下的答案:5 5 5

6樓:德迷聯盟

ch的值是(    65  )。

duwhile(ch=getchar()==’

zhia’);

5、int a[4]=,*p;p=a;此時*p的值是(3      ),dao*p++的值是(      6     ),(*p)++的值是(     5    )。

這是編譯器運內行出來的結容果。

7樓:窮圖末錄

110155

5注意++後置

8樓:匿名使用者

110,1,

5,3.6

c語言題目:下面程式段的輸出結果是什麼? 15

9樓:匿名使用者

答案是0

int k沒有初始化,所以初始值不確定,但是int型別 4個位元組(範圍是-2147483648~2147483647). 所以在計算k的值時候,從起始地址往下數32位, 超出32位的會被截斷

如果是正數,那最後就是0,很直觀

如果是負數(8個位元組來看)

0xffffffffffffffff === -10xfffffffffffffffe === -20xffffffff80000000 === -21474836480xffffffff7fffffff === -2147483649但整型4個位元組,所以對於-2147483649,它計算0x7fffffff的大小,變成了2147483647,回到正數,最後為0

10樓:匿名使用者

如果正確答案是a;那麼那個老師是有問題的;c語言中出現這種情況,答案是d才對

11樓:知道嗎

你沒賦值,預設數值為0 的

一道c語言題:下面的程式段執行後,輸出結果是

12樓:匿名使用者

答案是0;

int i,j,x=0;

static int a[8][8]; //定義的bai時候系統自動初du

始化,把陣列中zhi所有的元dao素都賦成0;

for(i=0;i<3;i++)

for(j=0;j<3;j++)

a[i][j]=2*i+j; //將陣列右上角的回3x3的子矩答陣賦值;(注意,此時結束時j的值是3)

for(i=0;i<8;i++)

x+=a[i][j];//這裡j的值是3,所以相當於把a[0][3] a[1][3] a[2][3]到a[7][3]累加到x上,而在上面的賦值中又沒有給這些值賦值,所以這些值都是0;而x的初值也是0,所以最後輸出的x應當為0;

printf("%d",x);

13樓:匿名使用者

用來static定義陣列,就已經給陣列初值了源,即使所有的值均為0.

你用for在給陣列賦值的時候,只給了a[0][0]至a[2][2]的值,即那些值現在已經有變化了.在經過兩個for之後,j的值應該變為了3.

那麼再經歷下一個for,應該執行的語句就是x+=a[i][3],可想而知,不論你經歷多少次迴圈,只要j是3,那麼些a[n][3]就是0.因為第3列根本就沒有變化過.值仍舊為0

所以結果為0

14樓:匿名使用者

static int a[8][8], a中的每個元素都是0

第三個for的時候 j=3, a[i][3]都是0,所以結果是0

15樓:匿名使用者

是0 e:\case.win\nasm>gcc z.c -o z.exe

e:\case.win\nasm>z

0 e:\case.win\nasm>

#include "stdio.h"

int main()

c語言有以下程式c語言有以下c程式includestdiohintmain

第一次進switch的bai時候du由於你的case 0 printf another n 後面沒有zhibreak 所以繼續執行了case 1 printf number n 結果就dao列印出來了 another number 第二專次switch的時候關於字元 1 匹配屬 case 1 pri...

c語言以下程式執行後的輸出結果是?請詳細說明

執行結果 13715 過程 i 1時,n 1 n 0 2 1 運算完得 到 n 列印輸出 n 1 i 2時,n 2 n 1 2 1 運算完得到 n 列印輸出 n 2 i 3時,n 3 n 2 2 1 運算完得到 n 列印輸出 n 3 i 4時,n 4 n 3 2 1 運算完得到 n 列印輸出 n 4...

以下程式的輸出結果fintbintm,int

程式zhi 是不是這樣 include int f int b int m,int n return s int main x f a,3,7 printf d n x return 0 執行如下 i 3時 專s 0 a 3 4 i 5時 s 4 a 5 4 6 10。結果為屬10。如果程式為f i...