C語(yǔ)言中的分支循環(huán)其嵌套語(yǔ)句
Hello,everyone! forever之前給大家介紹了C語(yǔ)言的分支結(jié)構(gòu)和循環(huán)結(jié)構(gòu),在分支中介紹了分支語(yǔ)句嵌套,但當(dāng)時(shí)沒(méi)有介紹 switch 嵌套,所以這次主要介紹 switch 嵌套和循環(huán)嵌套.
首先來(lái)說(shuō)說(shuō)什么是嵌套吧!一個(gè)語(yǔ)句內(nèi)包含另一個(gè)完整的語(yǔ)句結(jié)構(gòu)稱為語(yǔ)句嵌套。
內(nèi)嵌套的語(yǔ)句結(jié)構(gòu)內(nèi)還可以繼續(xù)嵌套其他語(yǔ)句結(jié)構(gòu),這就構(gòu)成多層嵌套。如:在循環(huán)體內(nèi)嵌套一個(gè)完整的循環(huán)語(yǔ)句,就稱為循環(huán)嵌套;在內(nèi)部循環(huán)嵌套里在嵌套一個(gè)循環(huán)結(jié)構(gòu),就是多層循環(huán)。
嵌套的含義是指“完整的包含”。
switch 嵌套
如同 if 語(yǔ)句一樣,switch 語(yǔ)句也可以構(gòu)成嵌套結(jié)構(gòu)。在 switch-case 內(nèi)部再嵌套一個(gè) switch-case 語(yǔ)句,就構(gòu)成 switch 嵌套結(jié)構(gòu);若內(nèi)部的內(nèi)部再繼續(xù)嵌套就會(huì)構(gòu)成多層嵌套。
1、語(yǔ)法結(jié)構(gòu)
以下是 switch 嵌套結(jié)構(gòu),default 可以看情況使用,不使用時(shí)就相當(dāng)于不處理。一般用 default 時(shí),在后面就可以不加 break。
switch (表達(dá)式1) { case 常量表達(dá)式1:語(yǔ)句1; ?? ?switch (表達(dá)式2) ?? ?{ ?? ?case 常量表達(dá)式A:語(yǔ)句a;? ?? ??? ?break; ?? ?case 常量表達(dá)式B:語(yǔ)句b; ?? ??? ?break; ?? ??? ?…… ?? ?default:語(yǔ)句N; ?? ?} ?? ?break; case 常量表達(dá)式2:語(yǔ)句2; ?? ?switch (表達(dá)式n) ?? ?{ ?? ??? ?…… ?? ?} ?? ?break; case 常量表達(dá)式3:語(yǔ)句3; ?? ?break; ?? ?…… default:語(yǔ)句n; }
2、switch-case 嵌套語(yǔ)句程序示例
例題一:簡(jiǎn)單的理解 switch 語(yǔ)句嵌套結(jié)構(gòu)
*簡(jiǎn)單的switch嵌套程序* #include<stdio.h> int main() { ?? ?int a = 0, b = 0; ?? ?scanf("%d %d", &a, &b); ? //先輸入兩個(gè)值 ?? ?switch (a) ? ?//這個(gè)外部 switch 對(duì) a 進(jìn)行判斷 ?? ?{ ?? ?case 1: ? ? ? //a=1時(shí)進(jìn)入內(nèi)部嵌套 switch 語(yǔ)句 ?? ??? ?switch (b) ? //這里 switch 對(duì) b 進(jìn)行判斷 ?? ??? ?{ ?? ??? ?case 0:printf("$$$\n"); ?? ??? ??? ?break; ?? ??? ?case 1:printf("&&&\n"); ?? ??? ?default:printf("***"); ? //這里是除了以上情況外的其他情況 ?? ??? ??? ?break; ?? ??? ?} ?? ??? ?break; ? //結(jié)束 case1 內(nèi)部的嵌套語(yǔ)句 ?? ?case 2:printf("###\n"); ?? ??? ?break; ?? ?case 3:printf("@@@\n"); ?? ?default:printf("!!!\n"); ?? ?} ?? ?return 0; }
運(yùn)行結(jié)果:
例題二:switch 和 if 的結(jié)合使用。請(qǐng)輸入星期幾的第一個(gè)字母來(lái)判斷是星期幾,如果第一個(gè)字母一樣則繼續(xù)判斷第二個(gè)字母。
*請(qǐng)輸入星期幾的第一個(gè)字母來(lái)判斷是星期幾,如果第一個(gè)字母一樣則繼續(xù)判斷第二個(gè)字母。* #include<stdio.h> #include<ctype.h>//這是toupper 函數(shù)調(diào)用頭文件 int main() { char letter1; char letter2; printf("請(qǐng)輸入星期中某一天的第一個(gè)字母:(M/W/F/T/S)\n"); scanf("%c", &letter1); letter1 = toupper(letter1);// toupper 是一個(gè)將小寫(xiě)字母轉(zhuǎn)換成大寫(xiě)字母的函數(shù) getchar();//利用 getchar 消除回車符'\n',如果沒(méi)有這個(gè) getchar , switch (letter1) //那么后面繼續(xù)輸入第二個(gè)字母時(shí)就會(huì)輸入回車符'\n',直接判斷為 error { case 'M':printf("星期一\n"); break; case 'W':printf("星期三\n"); break; case 'F':printf("星期五\n"); break; case 'T':printf("請(qǐng)輸入第二個(gè)字母:(u/h)\n"); scanf("%c", &letter2); if (letter2 == 'u')//case 內(nèi)部結(jié)合 if-else 語(yǔ)句使用 { printf("星期二\n"); } else if (letter2 == 'h') { printf("星期四\n"); } else { printf("error\n"); } break; case 'S':printf("請(qǐng)輸入第二個(gè)字母:(a/u)\n"); scanf("%c", &letter2); if (letter2 == 'a') { printf("星期六\n"); } else if (letter2 == 'u') { printf("星期天\n"); } else { printf("error\n"); } break; default:printf("error\n"); } return 0; }
運(yùn)行結(jié)果:查找星期二
循環(huán)嵌套
循環(huán)結(jié)構(gòu)的循環(huán)語(yǔ)句可以是任意合法的 C 語(yǔ)句。若一個(gè)循環(huán)結(jié)構(gòu)的循環(huán)體中包含了另一循環(huán)語(yǔ)句,則構(gòu)成了循環(huán)的嵌套,稱為多重循環(huán)。
嵌套的含義是指“完整的的包含”,那么循環(huán)的嵌套是指在一個(gè)循環(huán)的循環(huán)體內(nèi)完整的包含另一個(gè)或另外幾個(gè)循環(huán)結(jié)構(gòu)。C 語(yǔ)言中三種循環(huán)控制語(yǔ)句可以相互嵌套在一起。
1、while 循環(huán)嵌套
(1)語(yǔ)法結(jié)構(gòu):
while (表達(dá)式1) { 語(yǔ)句1; while(表達(dá)式2) { 語(yǔ)句2; } …… }
(2)while 循環(huán)嵌套程序示例
示例一:利用 while 循環(huán)嵌套打印九九乘法表
//打印九九乘法表 #include<stdio.h> int main() { int i = 1, j = 1; while (i < 10) { j = 1; while (j <= i) { printf("%d*%d=%-4d ", j, i, i * j);//%-4d意思是左對(duì)齊并且保證留四個(gè)字符長(zhǎng)度的距離 j++; } printf("\n");//起到換列的作用 i++; } return 0; }
運(yùn)行結(jié)果:九九乘法表打印
2、do-while 嵌套循環(huán)
(1)語(yǔ)法結(jié)構(gòu)
do { 語(yǔ)句1; do { 語(yǔ)句2; } while ();//一定要注意do-while語(yǔ)句后面的“分號(hào)”,不能丟 …… } while ();
(2)do-while 循環(huán)嵌套示例
隨機(jī)打印2-n+1個(gè)數(shù)字
#include<stdio.h>//隨機(jī)打印 2-n+1 個(gè)數(shù) int main() { int i = 0; int n = 0; scanf("%d", &n); do { i++; do { i++; printf("%d\n", i); } while (i <= n); } while(i<=n); return 0; }
運(yùn)行結(jié)果:
3、for 循環(huán)嵌套
(1)語(yǔ)法結(jié)構(gòu)
for ( ; ; ) { 語(yǔ)句1; for( ; ; ) { 語(yǔ)句2; } …… }
(2)for 循環(huán)嵌套示例
示例一:數(shù)字金字塔
//利用 for 循環(huán)嵌套實(shí)現(xiàn)數(shù)字金字塔 #include<stdio.h>//數(shù)字金字塔 int main() { int i = 0, j = 0; int n = 0; scanf("%d", &n); for (i = 1; i <= n; i++) { for (j = n-i; j >0; j--)//此循環(huán)語(yǔ)句為了實(shí)現(xiàn)空格打印 { printf(" "); } for (j = 1; j <= i; j++) { printf("%d ", i); } printf("\n");//實(shí)現(xiàn)換行 } return 0; }
運(yùn)行結(jié)果:輸入5,進(jìn)行金字塔排列
示例二:冒泡排序法
for 循環(huán)實(shí)現(xiàn)從小到大冒泡排序
//利用 for 循環(huán)嵌套實(shí)現(xiàn)從小到大冒泡排序 #include<stdio.h>//冒泡排序 int main() { int n = 0; int i = 0, j = 0; int arr[100] = { 0 }; int temp = 0; scanf("%d", &n); for (i = 0; i < n; i++)//利用循環(huán)給數(shù)組賦值 { scanf("%d", &arr[i]); } for (i = 0; i < n - 1; i++)//冒泡排序外層循環(huán)進(jìn)行 n-1 輪排序 { for (j = 0; j < n - i - 1; j++)//冒泡排序內(nèi)層循環(huán)每輪要進(jìn)行 n-i-1 層比較 { if (arr[j] > arr[j + 1])//進(jìn)行大小比較 { temp = arr[j]; arr[j] = arr[j + 1]; arr[j + 1] = temp; } } } for (i = 0; i < n; i++) { printf("%d ", arr[i]); } return 0; }
運(yùn)行結(jié)果:隨機(jī)輸入5個(gè)數(shù)進(jìn)行排序
示例三:打印 100-200 之間的素?cái)?shù)
for 循環(huán)嵌套打印100-200間素?cái)?shù)
//打印100-200間素?cái)?shù) #include<stdio.h>//打印100-200間素?cái)?shù) int main() { int j = 0; for (int i = 100; i <= 200; i++) { for (j = 2; j < i; j++) { if (i % j == 0) { break; } } if (i == j) { printf("%d\n", i); } } return 0; }
運(yùn)行結(jié)果:
總結(jié)
1、在循環(huán)以及循環(huán)嵌套中依然會(huì)常用到 break 和 continue ,之前文章詳細(xì)介紹過(guò)這兩個(gè)語(yǔ)句,因此要注意他們的使用;
2、再多層嵌套里一般也會(huì)用到 goto 跳轉(zhuǎn)語(yǔ)句,終止程序在某些結(jié)構(gòu)中的深度嵌套;
3、除以上基本嵌套之外,while、do-while、for以及和其他分支語(yǔ)句都可以任意嵌套組合使用,而且 C 語(yǔ)言中不限制嵌套的層數(shù),我們可以合理組織程序的模塊結(jié)構(gòu);
4、在編寫(xiě)程序時(shí),盡量避免過(guò)多的嵌套,影響代碼整體美觀,嵌套過(guò)多也對(duì)硬件相關(guān)配置要求更高。
目前就這些!這些代碼都比較簡(jiǎn)單,淺顯易懂,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
以上代碼均可運(yùn)行,所用編譯環(huán)境為 vs2019 ,運(yùn)行時(shí)注意加上編譯頭文件#define _CRT_SECURE_NO_WARNINGS 1
相關(guān)文章
C程序中Ubuntu、stm32的內(nèi)存分配問(wèn)題
這篇文章主要介紹了C程序中Ubuntu、stm32的內(nèi)存分配問(wèn)題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-12-12C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單三子棋游戲
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單三子棋游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-09-09C語(yǔ)言實(shí)現(xiàn)楊輝三角實(shí)例
這篇文章主要介紹了C語(yǔ)言實(shí)現(xiàn)楊輝三角的方法,主要通過(guò)數(shù)組簡(jiǎn)單實(shí)現(xiàn),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2014-09-09C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之二叉樹(shù)的非遞歸后序遍歷算法
這篇文章主要介紹了C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之二叉樹(shù)的非遞歸后序遍歷算法的相關(guān)資料,希望通過(guò)本文能幫助到大家,讓大家實(shí)現(xiàn)這樣的功能,需要的朋友可以參考下2017-10-10Qt出現(xiàn)假死凍結(jié)現(xiàn)象的原因及解決方法
應(yīng)用程序出現(xiàn)假死或凍結(jié)現(xiàn)象通常是由于一些常見(jiàn)問(wèn)題所導(dǎo)致的,本文主要介紹了Qt出現(xiàn)假死凍結(jié)現(xiàn)象的原因及解決方法,具有一定的參考價(jià)值,感興趣的可以了解一下2023-10-10C語(yǔ)言實(shí)現(xiàn)的一個(gè)三子棋游戲詳解流程
三子棋是一種民間傳統(tǒng)游戲,又叫九宮棋、圈圈叉叉、一條龍、井字棋等。將正方形對(duì)角線連起來(lái),相對(duì)兩邊依次擺上三個(gè)雙方棋子,只要將自己的三個(gè)棋子走成一條線,對(duì)方就算輸了2021-10-10大數(shù)據(jù)情況下桶排序算法的運(yùn)用與C++代碼實(shí)現(xiàn)示例
在排序元素很多的情況下,其實(shí)桶排序的性能并不是太高,這里我們配合單鏈表的直接插入排序,來(lái)看下一大數(shù)據(jù)情況下桶排序算法的運(yùn)用與C++代碼實(shí)現(xiàn)示例:2016-07-07