網(wǎng)站首頁 編程語言 正文
switch語句
我們先了解switch是什么,翻譯過來的中文意思是開關(guān),在C語言中是指選擇不同的開關(guān)即不同的分支來完成語句。接下來講一下switch的結(jié)構(gòu)和基本使用。
一般的switch語句的結(jié)構(gòu) switch(n){ case 1: 語句1; break; case 2: 語句2; break; case 3: 語句3; break; default: 語句4; break; }//當(dāng)然我們一般也喜歡用{}來包括case后面得語句和break 即case 常量/表達(dá)式:{ 語句; 語句; break; }
switch語句是從case進(jìn),break出,case后面只能跟常量或者常量表達(dá)式
,n是一個(gè)變量,與if不同的是,if是判斷表達(dá)值是真或假
,而switch判斷的是變量中儲存的值具體是多少
,然后根據(jù)這個(gè)值尋找對應(yīng)的case,當(dāng)所有的case均無法進(jìn)入時(shí)會進(jìn)入default這個(gè)最后的入口
。switch的使用情況一般就是菜單使用和成績表等的等級劃分等。菜單使用相信大家能夠理解,n為不同的值的時(shí)候我們會進(jìn)行不同的操作,那么成績表的等級劃分是什么情況呢?
如果你要把九十分以上的人認(rèn)作是優(yōu)秀,八十分以上定義成良好 七十分以上為,中等六十以上不及格,六十以下不及格 你該怎么設(shè)計(jì)程序根據(jù)一個(gè)人的分?jǐn)?shù)打印他的等級呢? 或許你會選擇這樣的一串代碼 if(n>=90) printf("優(yōu)秀"); else if(n>=80) printf("良好"); else if(n>=70) printf("中等"); else if(n>=60) printf("及格"); else printf("不及格"); 這個(gè)代碼可以清晰的表示你的意思,這樣分支代碼會有點(diǎn)搓 而switch十分適合這種,這個(gè)時(shí)候肯定會有朋友們疑惑, case后面只能跟一個(gè)具體的常量,不能跟一個(gè)范圍,那么一個(gè)一個(gè) 的寫 case 100 case 99 case 98 . . case 0 但并不是這樣實(shí)現(xiàn)的,一般就行等級規(guī)劃的時(shí)候都是有一個(gè)共同的特點(diǎn) 我們既可以根據(jù)這個(gè)特點(diǎn)來設(shè)計(jì)switch switch(n/10){ case 10: case 9: case 8: case 7: case 6: default : }//具體的代碼實(shí)現(xiàn)就寫到這,主要是分享思路
switch和if的區(qū)別
前面只是淺談了switch,接下來看兩張圖片幫助你深入了解switch,并認(rèn)清switch和if的區(qū)別
1.switch語句結(jié)構(gòu)示意圖
第一次畫圖,可能畫的有點(diǎn)難看,希望見諒
2.if語句結(jié)構(gòu)示意圖
看完這兩張圖后,我們來深入了解switch
- 1.與其說switch是分支結(jié)構(gòu),不如說它是順序結(jié)構(gòu)。
- 雖然說switch是從不同的case進(jìn)入整個(gè)switch內(nèi)部的,但是我們要知道,switch從case進(jìn)入以后只有兩種到達(dá)出口的方式,遇到break和switch語句全部結(jié)束,根據(jù)結(jié)構(gòu)圖也可以知道其實(shí)switch的不同語句塊之間其實(shí)是從上往下排列的,與順序結(jié)構(gòu)是類似的。
- 2.if和switch結(jié)構(gòu)上的區(qū)別
- 根據(jù)兩張圖我們可以清晰的發(fā)現(xiàn),switch的結(jié)構(gòu)類似順序結(jié)構(gòu),而if是互相并列的分支結(jié)構(gòu),if最多只會執(zhí)行其中第一個(gè)判斷為真的語句塊,而switch在沒有break傳送門情況下會一直運(yùn)行進(jìn)入入口后的語句塊直到找到了出口。
- 3.if和switch共同的分支結(jié)構(gòu)
- switch既然屬于分支語句,那么就一定存在分支的地方。switch的case語句是分支的,即入口是分支的,這一點(diǎn)和if是一致的,他們的入口都是分支的,并且都是在程序運(yùn)行時(shí)是從上往下逐步判斷是否可以這個(gè)入口進(jìn)入語句塊內(nèi)部。
switch的高級(靈活)運(yùn)用
了解了switch的具體結(jié)構(gòu)及其與if的區(qū)別,接下來講一下如何靈活的運(yùn)用switch,或者在試題中如何
分析答案
高級的switch使用,其實(shí)就兩個(gè)要點(diǎn),靈活利用break和合理對case進(jìn)行適當(dāng)?shù)呐判? 比如剛剛的成績劃分程序,100分和九十多分是一樣的,我們可以進(jìn)行這樣的簡化 case 10: case 9: printf("優(yōu)秀"); break; 其實(shí)這種情況非常的簡單,大家實(shí)際遇到或者運(yùn)用的時(shí)候或許會復(fù)雜很多 但是只要找到程序的特點(diǎn),并且記住switch的結(jié)構(gòu)以及牢記到達(dá)出口的條件, 大家就可以很輕松的分析程序,并且在慢慢的積累中熟練的掌握。
switch的嵌套實(shí)現(xiàn)
switch同樣也可以嵌套,看著或許復(fù)雜,但在培養(yǎng)了一定的程序的思維之后并不難理解,接下來用這個(gè)代碼來幫助大家簡單的理解switch的嵌套使用。
這段代碼可用于判斷科舉時(shí)進(jìn)士的前三甲 #include<stdio.h> int main(){ int n; //存放名次,并用于判斷 printf("請告訴我你的排名:"); scanf("%d",&n); switch (n / 30) { case 0: //n/30等于0,即前三十名,進(jìn)入下一層switch switch (n) { case 1: printf("狀元"); //第一名狀元 break; case 2: printf("榜眼"); //第二名榜眼 break; case 3: printf("探花"); //第三名探花 break; default: printf("進(jìn)士及第"); //其余是進(jìn)士及第 } break; case 1: //n/30等于1為30-59名 switch (n) { //進(jìn)入下一層switch,30進(jìn)士及第,其余同進(jìn)士及第 case 30: printf("進(jìn)士及第"); break; default: printf("同進(jìn)士及第"); } break; case 2://60-89名,進(jìn)入下一層switch switch (n) { //60名為最后一位進(jìn)士,其余全部落榜 case 60: printf("同進(jìn)士及第"); break; default: printf("很遺憾你落榜了"); } break; default: printf("很遺憾你落榜了"); } return 0; } default因?yàn)槭亲詈蟮娜肟冢钥梢允÷詁reak 但在還未靈活使用break和case時(shí)建議不要省略break
循環(huán)及循環(huán)的兩個(gè)關(guān)鍵字
什么是循環(huán)結(jié)構(gòu)
循環(huán)簡單來說就是,重復(fù)反復(fù)的進(jìn)行一些同樣的操作,這個(gè)時(shí)候?yàn)榱斯?jié)省代碼量,提高代碼的美觀性時(shí),我們會用循環(huán)語句來包裝那些重復(fù)的語句,而循環(huán)語句中不斷執(zhí)行的語句被稱為循環(huán)體。
下面大家可以根據(jù)這個(gè)簡單的圖來理解循環(huán)
這只是其中的一種循環(huán),為了達(dá)到美好的生活,我們不停的學(xué)習(xí),敲代碼,買彩票,直到拿到工作或者彩票中大獎,希望大家看完之后能簡單理解循環(huán)。
break關(guān)鍵字
在switch中,break是一個(gè)傳送門,直接帶我們走到出口,在循環(huán)中也是同樣的,break會打破最近的一層循環(huán),作為一個(gè)傳送門帶我們達(dá)到美好新生活而不需要判斷是否中獎或者是否有offer
continue關(guān)鍵字
continue在循環(huán)中的作用是結(jié)束這次循環(huán)開始下一次循環(huán),我更喜歡稱它為閃現(xiàn),那什么叫結(jié)束本次循環(huán)呢,比如我們在學(xué)習(xí)后加上一個(gè)continue,我們就不需要再敲代碼和買彩票了,但和break不同,它還需要進(jìn)行下一次循環(huán),走出循環(huán)的條件只有兩個(gè)就是不符合判定循環(huán)條件和break打破循環(huán),當(dāng)遇到continue時(shí)程序會直接結(jié)束本次循環(huán),然后到達(dá)循環(huán)判定條件處來進(jìn)行判定,以判斷是否要進(jìn)行下一次循環(huán),并不能直接送你到達(dá)出口。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持AB教程網(wǎng)。
原文鏈接:https://blog.csdn.net/weixin_62753802/article/details/121916764
相關(guān)推薦
- 2022-05-03 ASP.NET?Core基于滑動窗口實(shí)現(xiàn)限流控制_實(shí)用技巧
- 2022-08-19 Go語言fsnotify接口實(shí)現(xiàn)監(jiān)測文件修改_Golang
- 2022-08-18 python高階函數(shù)使用教程示例_python
- 2022-10-13 解析批處理命令call和start_DOS/BAT
- 2022-10-11 線上nginx偶爾出現(xiàn)502錯(cuò)誤
- 2022-07-13 Python中常用序列數(shù)據(jù)結(jié)構(gòu)
- 2022-04-30 C語言實(shí)現(xiàn)小型工資管理系統(tǒng)_C 語言
- 2023-06-13 C語言函數(shù)多個(gè)返回值方式_C 語言
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支