C語言分支循環(huán)其嵌套語句的使用
Hello,everyone! forever之前給大家介紹了C語言的分支結(jié)構(gòu)和循環(huán)結(jié)構(gòu),在分支中介紹了分支語句嵌套,但當(dāng)時(shí)沒有介紹 switch 嵌套,所以這次主要介紹 switch 嵌套和循環(huán)嵌套.
首先來說說什么是嵌套吧!一個(gè)語句內(nèi)包含另一個(gè)完整的語句結(jié)構(gòu)稱為語句嵌套。內(nèi)嵌套的語句結(jié)構(gòu)內(nèi)還可以繼續(xù)嵌套其他語句結(jié)構(gòu),這就構(gòu)成多層嵌套。如:在循環(huán)體內(nèi)嵌套一個(gè)完整的循環(huán)語句,就稱為循環(huán)嵌套;在內(nèi)部循環(huán)嵌套里在嵌套一個(gè)循環(huán)結(jié)構(gòu),就是多層循環(huán)。嵌套的含義是指“完整的包含”。
switch 嵌套
如同 if 語句一樣,switch 語句也可以構(gòu)成嵌套結(jié)構(gòu)。在 switch-case 內(nèi)部再嵌套一個(gè) switch-case 語句,就構(gòu)成 switch 嵌套結(jié)構(gòu);若內(nèi)部的內(nèi)部再繼續(xù)嵌套就會(huì)構(gòu)成多層嵌套。
1、語法結(jié)構(gòu):
以下是 switch 嵌套結(jié)構(gòu),default 可以看情況使用,不使用時(shí)就相當(dāng)于不處理。一般用 default 時(shí),在后面就可以不加 break。
switch (表達(dá)式1)
{
case 常量表達(dá)式1:語句1;
switch (表達(dá)式2)
{
case 常量表達(dá)式A:語句a;
break;
case 常量表達(dá)式B:語句b;
break;
……
default:語句N;
}
break;
case 常量表達(dá)式2:語句2;
switch (表達(dá)式n)
{
……
}
break;
case 常量表達(dá)式3:語句3;
break;
……
default:語句n;
}
2、switch-case 嵌套語句程序示例
例題一:簡(jiǎn)單的理解 switch 語句嵌套結(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 語句
switch (b) //這里 switch 對(duì) b 進(jìn)行判斷
{
case 0:printf("$$$\n");
break;
case 1:printf("&&&\n");
default:printf("***"); //這里是除了以上情況外的其他情況
break;
}
break; //結(jié)束 case1 內(nèi)部的嵌套語句
case 2:printf("###\n");
break;
case 3:printf("@@@\n");
default:printf("!!!\n");
}
return 0;
}
運(yùn)行結(jié)果:

例題二:switch 和 if 的結(jié)合使用。請(qǐng)輸入星期幾的第一個(gè)字母來判斷是星期幾,如果第一個(gè)字母一樣則繼續(xù)判斷第二個(gè)字母。
運(yùn)行結(jié)果:查找星期二

循環(huán)嵌套
循環(huán)結(jié)構(gòu)的循環(huán)語句可以是任意合法的 C 語句。若一個(gè)循環(huán)結(jié)構(gòu)的循環(huán)體中包含了另一循環(huán)語句,則構(gòu)成了循環(huán)的嵌套,稱為多重循環(huán)。嵌套的含義是指“完整的的包含”,那么循環(huán)的嵌套是指在一個(gè)循環(huán)的循環(huán)體內(nèi)完整的包含另一個(gè)或另外幾個(gè)循環(huán)結(jié)構(gòu)。C 語言中三種循環(huán)控制語句可以相互嵌套在一起。
1、while 循環(huán)嵌套
(1)語法結(jié)構(gòu):
while (表達(dá)式1)
{
語句1;
while(表達(dá)式2)
{
語句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)語法結(jié)構(gòu)
do
{
語句1;
do
{
語句2;
} while ();//一定要注意do-while語句后面的“分號(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)語法結(jié)構(gòu)
for ( ; ; )
{
語句1;
for( ; ; )
{
語句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)語句為了實(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ì)介紹過這兩個(gè)語句,因此要注意他們的使用;
2、再多層嵌套里一般也會(huì)用到 goto 跳轉(zhuǎn)語句,終止程序在某些結(jié)構(gòu)中的深度嵌套;
3、除以上基本嵌套之外,while、do-while、for以及和其他分支語句都可以任意嵌套組合使用,而且 C 語言中不限制嵌套的層數(shù),我們可以合理組織程序的模塊結(jié)構(gòu);
4、在編寫程序時(shí),盡量避免過多的嵌套,影響代碼整體美觀,嵌套過多也對(duì)硬件相關(guān)配置要求更高。
目前就這些!這些代碼都比較簡(jiǎn)單,淺顯易懂,希望對(duì)一些初學(xué)者有一定幫助,也望其他大佬能多多指點(diǎn)!如有不足或錯(cuò)誤之處,請(qǐng)諒解并指教哈!
謝謝觀看,再見啦!
以上代碼均可運(yùn)行,所用編譯環(huán)境為 vs2019 ,運(yùn)行時(shí)注意加上編譯頭文件#define _CRT_SECURE_NO_WARNINGS 1
到此這篇關(guān)于C語言分支循環(huán)其嵌套語句的使用的文章就介紹到這了,更多相關(guān)C語言分支循環(huán)其嵌套內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言實(shí)現(xiàn)順序循環(huán)隊(duì)列實(shí)例
大家好,本篇文章主要講的是C語言實(shí)現(xiàn)順序循環(huán)隊(duì)列實(shí)例,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下2022-02-02
C++知識(shí)點(diǎn)之成員函數(shù)中const的用法
這篇文章主要介紹了C++知識(shí)點(diǎn)之成員函數(shù)中const的用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11
C語言中隱藏結(jié)構(gòu)體的細(xì)節(jié)
以筆者粗淺的認(rèn)識(shí),有兩種最常用的方法,可以實(shí)現(xiàn)庫內(nèi)結(jié)構(gòu)體定義的隱藏:接口函數(shù)形參使用結(jié)構(gòu)體指針,接口函數(shù)形參使用句柄。2017-05-05

