本文目錄一覽:
c語言switch為什麼不執行?
因為代碼寫的不對,switch得不到自己需要的類型,所以才會不能執行。c語言寫的時候一定要注重寫法
為什麼我switch語句一里的scanf沒有運行
switch 語句用法
功能:switch語句是多分支選擇語句.用來實現多分支選擇結構.if語句只有兩個分支可供選擇,而實際問題中常常要用到多分支的選擇.例如,學生成績分類(90為”A”等,80-89分為’B’等,70-90分為’C’等……).當然這些都可以用嵌套的if語句來外理,但如果分支較多,則嵌套的if語句層數多,程序沉余長而且可讀性降低.C語言提供switch語句直接外理多分支選擇,它相當於PASCAL語言中的CASE語句.
形式:switch(表達式)
{
case 常量表達式 1:語句 1
case 常量表達式 2:語句 2
.
.
.
case 常量表達式 n:語句 n
default:語句 n+1
}
例如,要求按照考試成績的等級打印出百分制分數段,可以用switch語句實現:
switch(grade)
{
case ‘A’:printf(“85-100\n”);
case ‘B’:printf(“70-84\n”);
case ‘C’:printf(“60-69\n”);
case ‘D’:printf(“60\n”);
default:printf(“error\n”);
}
說明:
(1) switch後面括弧內的”表達式”,ANSI標準允許它為任何類型.
(2) 當表達式的值與某一個case後面的常量表達式的值相等時,就執行此case後面的語句,若所有的case中的常量表達式的值都沒有與表達式的匹配的,就執行default後面的語句.
(3) 每一個case的常量表達式的值必須互不相同,否則就會出現互相矛盾的現象(對表達式的同一個值,有兩種或多種執行方案).
(4) 各個case各default的出現次序不影響執行結果。例如,可以先出現”default: …”,再出現”case ‘D’: …”,然後是”case ‘A’: …”.
(5) 執行完一個case後面的語句後,流程控制轉移到下一個case繼續執行.”case常量表達式”只是起語句標號作用,並不是在該處進行條件判斷.在執行swith語句時,根據switch後面表達式的值找到匹配的入口標號,就從此標號開始執行下去,不再進行判斷.例如,上面的例子中,若grade的值等於’A’,則將連續輸出:
85-100
70-84
60-69
60
error
因此,應該在執行一個case分支後,使流程跳出switch結構,即終止switch語句的執行.
可以用一個break語句來達到此目的.將上面的switch結構改寫如下:
switch(grade)
{
case ‘A’:printf(“85-100\n”); break;
case ‘B’:printf(“70-84\n”); break;
case ‘C’:printf(“60-69\n”); break;
case ‘D’:printf(“60\n”); break;
default:printf(“error\n”);
}
最後一個分支(default)可以不加break語句.如果grade的值為’B’,則只輸出”70-84″.
在case後面中雖然包含一個以上執行語句,但可以不必用花括弧括起來,會自動順序執行本case後面所有的執行語句.當然加上花括弧也可以.
(6) 多個case可以共用一組執行語句,例如:
.
.
.
case ‘A’:
case ‘B’:
case ‘C’: printf(“60\n”);break;
.
.
.
grade的值為’A’,’B’或’C’時都執行同一組語句
C語言循環里scanf用不了
肯定是因為game()函數里有scanf語句,並且scanf之後沒有處理scanf留下的換行符。
scanf從屏幕是讀取數據時,往往不會自動讀掉行尾的換行符(你輸入數據後,肯定會按一個回車的對吧),所以在game函數里的最後一個scanf結束後,輸入緩衝區里還一個換行符在裡面,這個時候main函數里的scanf函數讀到的字符就是那個換行符
解決方法:
在game函數的最後一個scanf函數後面,加上一個gets語句,用來讀掉最後一個換行符即可,當然如果你的輸出里敲了多個回車,就要執行多句,不懂可以貼上你的game()函數和你上面的輸入,我再告訴你
C語言中關於字符數組輸入,scanf為什麼沒執行
這種情況通常發生在前面已經有了輸入語句,而當前的scanf是在接收字符(即用%c控制輸入)時。由於前面的輸入語句(不一定是scanf)把最後輸入的’\n’遺留在了輸入緩衝區,而當前的scanf(“%c”,…);又會把’\n’當一個字符接收,又由於scanf在%c控制下只接收一個字符,所以就不能接收正式輸入的字符了。解決這一問題的最簡單辦法是在接收字符的scanf的控制符”%c”中的%前加一個空格寫成”
%c”,把前一次輸入遺留在輸入緩衝區里的所有廣義空格(‘
‘、’\t’、’\n’等)都吸收掉。在接收字符的scanf前加getchar()等的辦法其實是有漏洞的——當緩衝區里只遺留了一個廣義字符時可正常工作,若多於一個則同樣出錯。
原創文章,作者:TTJI,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/132542.html