網站首頁 編程語言 正文
Hello,everyone! forever之前給大家介紹了C語言的分支結構和循環結構,在分支中介紹了分支語句嵌套,但當時沒有介紹 switch 嵌套,所以這次主要介紹 switch 嵌套和循環嵌套.
首先來說說什么是嵌套吧!一個語句內包含另一個完整的語句結構稱為語句嵌套。
內嵌套的語句結構內還可以繼續嵌套其他語句結構,這就構成多層嵌套。如:在循環體內嵌套一個完整的循環語句,就稱為循環嵌套;在內部循環嵌套里在嵌套一個循環結構,就是多層循環。
嵌套的含義是指“完整的包含”。
switch 嵌套
如同 if 語句一樣,switch 語句也可以構成嵌套結構。在 switch-case 內部再嵌套一個 switch-case 語句,就構成 switch 嵌套結構;若內部的內部再繼續嵌套就會構成多層嵌套。
1、語法結構
以下是 switch 嵌套結構,default 可以看情況使用,不使用時就相當于不處理。一般用 default 時,在后面就可以不加 break。
switch (表達式1)
{
case 常量表達式1:語句1;
?? ?switch (表達式2)
?? ?{
?? ?case 常量表達式A:語句a;?
?? ??? ?break;
?? ?case 常量表達式B:語句b;
?? ??? ?break;
?? ??? ?……
?? ?default:語句N;
?? ?}
?? ?break;
case 常量表達式2:語句2;
?? ?switch (表達式n)
?? ?{
?? ??? ?……
?? ?}
?? ?break;
case 常量表達式3:語句3;
?? ?break;
?? ?……
default:語句n;
}
2、switch-case 嵌套語句程序示例
例題一:簡單的理解 switch 語句嵌套結構
*簡單的switch嵌套程序*
#include<stdio.h>
int main()
{
?? ?int a = 0, b = 0;
?? ?scanf("%d %d", &a, &b); ? //先輸入兩個值
?? ?switch (a) ? ?//這個外部 switch 對 a 進行判斷
?? ?{
?? ?case 1: ? ? ? //a=1時進入內部嵌套 switch 語句
?? ??? ?switch (b) ? //這里 switch 對 b 進行判斷
?? ??? ?{
?? ??? ?case 0:printf("$$$\n");
?? ??? ??? ?break;
?? ??? ?case 1:printf("&&&\n");
?? ??? ?default:printf("***"); ? //這里是除了以上情況外的其他情況
?? ??? ??? ?break;
?? ??? ?}
?? ??? ?break; ? //結束 case1 內部的嵌套語句
?? ?case 2:printf("###\n");
?? ??? ?break;
?? ?case 3:printf("@@@\n");
?? ?default:printf("!!!\n");
?? ?}
?? ?return 0;
}
運行結果:
例題二:switch 和 if 的結合使用。請輸入星期幾的第一個字母來判斷是星期幾,如果第一個字母一樣則繼續判斷第二個字母。
*請輸入星期幾的第一個字母來判斷是星期幾,如果第一個字母一樣則繼續判斷第二個字母。*
#include<stdio.h>
#include<ctype.h>//這是toupper 函數調用頭文件
int main()
{
char letter1;
char letter2;
printf("請輸入星期中某一天的第一個字母:(M/W/F/T/S)\n");
scanf("%c", &letter1);
letter1 = toupper(letter1);// toupper 是一個將小寫字母轉換成大寫字母的函數
getchar();//利用 getchar 消除回車符'\n',如果沒有這個 getchar ,
switch (letter1) //那么后面繼續輸入第二個字母時就會輸入回車符'\n',直接判斷為 error
{
case 'M':printf("星期一\n");
break;
case 'W':printf("星期三\n");
break;
case 'F':printf("星期五\n");
break;
case 'T':printf("請輸入第二個字母:(u/h)\n");
scanf("%c", &letter2);
if (letter2 == 'u')//case 內部結合 if-else 語句使用
{
printf("星期二\n");
}
else if (letter2 == 'h')
{
printf("星期四\n");
}
else
{
printf("error\n");
}
break;
case 'S':printf("請輸入第二個字母:(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;
}
運行結果:查找星期二
循環嵌套
循環結構的循環語句可以是任意合法的 C 語句。若一個循環結構的循環體中包含了另一循環語句,則構成了循環的嵌套,稱為多重循環。
嵌套的含義是指“完整的的包含”,那么循環的嵌套是指在一個循環的循環體內完整的包含另一個或另外幾個循環結構。C 語言中三種循環控制語句可以相互嵌套在一起。?
1、while 循環嵌套?
(1)語法結構:
while (表達式1)
{
語句1;
while(表達式2)
{
語句2;
}
……
}
(2)while 循環嵌套程序示例
示例一:利用 while 循環嵌套打印九九乘法表
//打印九九乘法表
#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意思是左對齊并且保證留四個字符長度的距離
j++;
}
printf("\n");//起到換列的作用
i++;
}
return 0;
}
運行結果:九九乘法表打印
2、do-while 嵌套循環
(1)語法結構
do
{
語句1;
do
{
語句2;
} while ();//一定要注意do-while語句后面的“分號”,不能丟
……
} while ();
(2)do-while 循環嵌套示例
隨機打印2-n+1個數字
#include<stdio.h>//隨機打印 2-n+1 個數
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;
}
運行結果:
3、for 循環嵌套?
(1)語法結構
for ( ; ; )
{
語句1;
for( ; ; )
{
語句2;
}
……
}
(2)for 循環嵌套示例
示例一:數字金字塔
//利用 for 循環嵌套實現數字金字塔
#include<stdio.h>//數字金字塔
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--)//此循環語句為了實現空格打印
{
printf(" ");
}
for (j = 1; j <= i; j++)
{
printf("%d ", i);
}
printf("\n");//實現換行
}
return 0;
}
運行結果:輸入5,進行金字塔排列
示例二:冒泡排序法
for 循環實現從小到大冒泡排序
//利用 for 循環嵌套實現從小到大冒泡排序
#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++)//利用循環給數組賦值
{
scanf("%d", &arr[i]);
}
for (i = 0; i < n - 1; i++)//冒泡排序外層循環進行 n-1 輪排序
{
for (j = 0; j < n - i - 1; j++)//冒泡排序內層循環每輪要進行 n-i-1 層比較
{
if (arr[j] > arr[j + 1])//進行大小比較
{
temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
for (i = 0; i < n; i++)
{
printf("%d ", arr[i]);
}
return 0;
}
運行結果:隨機輸入5個數進行排序
示例三:打印 100-200 之間的素數
for 循環嵌套打印100-200間素數
//打印100-200間素數
#include<stdio.h>//打印100-200間素數
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;
}
運行結果:
總結
1、在循環以及循環嵌套中依然會常用到 break 和 continue ,之前文章詳細介紹過這兩個語句,因此要注意他們的使用;
2、再多層嵌套里一般也會用到 goto 跳轉語句,終止程序在某些結構中的深度嵌套;
3、除以上基本嵌套之外,while、do-while、for以及和其他分支語句都可以任意嵌套組合使用,而且 C 語言中不限制嵌套的層數,我們可以合理組織程序的模塊結構;
4、在編寫程序時,盡量避免過多的嵌套,影響代碼整體美觀,嵌套過多也對硬件相關配置要求更高。
目前就這些!這些代碼都比較簡單,淺顯易懂,希望能給大家一個參考,也希望大家多多支持AB教程網。?
原文鏈接:https://blog.csdn.net/m0_56817529/article/details/120734125
相關推薦
- 2023-07-17 uniapp開發,打包成H5部署到服務器
- 2022-10-12 C#集合本質之鏈表的用法詳解_C#教程
- 2022-11-18 C++簡單實現shared_ptr的代碼_C 語言
- 2022-09-21 Android?Intent傳遞大量數據出現問題解決_Android
- 2022-08-01 C#線程池ThreadPool用法簡介_C#教程
- 2022-03-29 C++初階學習之模板進階_C 語言
- 2022-06-25 Python制作簡易計算器功能_python
- 2022-10-17 python中list列表復制的幾種方法(賦值、切片、copy(),deepcopy())_pyth
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支