欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語(yǔ)言分支循環(huán)其嵌套語(yǔ)句的使用

 更新時(shí)間:2021年11月14日 09:31:01   作者:<For forever>  
本文主要介紹了switch 嵌套和循環(huán)嵌套,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

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)稱(chēng)為語(yǔ)句嵌套。內(nèi)嵌套的語(yǔ)句結(jié)構(gòu)內(nèi)還可以繼續(xù)嵌套其他語(yǔ)句結(jié)構(gòu),這就構(gòu)成多層嵌套。如:在循環(huán)體內(nèi)嵌套一個(gè)完整的循環(huán)語(yǔ)句,就稱(chēng)為循環(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(xiāo);
	}
	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 消除回車(chē)符'\n',如果沒(méi)有這個(gè) getchar ,
	switch (letter1)     //那么后面繼續(xù)輸入第二個(gè)字母時(shí)就會(huì)輸入回車(chē)符'\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é)果:查找星期二

請(qǐng)?zhí)砑訄D片描述

循環(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)的嵌套,稱(chēng)為多重循環(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é)果:九九乘法表打印

請(qǐng)?zhí)砑訄D片描述

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é)果:

請(qǐng)?zhí)砑訄D片描述

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)行金字塔排列

請(qǐng)?zhí)砑訄D片描述

示例二:冒泡排序法
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 輪排序![請(qǐng)?zhí)砑訄D片描述](https://img-blog.csdnimg.cn/9caa20aa99b742fc99e480f65f3c12ac.png)

	{
		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)行排序

請(qǐng)?zhí)砑訄D片描述

示例三:打印 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é)果:

請(qǐng)?zhí)砑訄D片描述

總結(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ān),嵌套過(guò)多也對(duì)硬件相關(guān)配置要求更高。
目前就這些!這些代碼都比較簡(jiǎn)單,淺顯易懂,希望對(duì)一些初學(xué)者有一定幫助,也望其他大佬能多多指點(diǎn)!如有不足或錯(cuò)誤之處,請(qǐng)諒解并指教哈!
謝謝觀(guān)看,再見(jiàn)啦!
以上代碼均可運(yùn)行,所用編譯環(huán)境為 vs2019 ,運(yùn)行時(shí)注意加上編譯頭文件#define _CRT_SECURE_NO_WARNINGS 1

到此這篇關(guān)于C語(yǔ)言分支循環(huán)其嵌套語(yǔ)句的使用的文章就介紹到這了,更多相關(guān)C語(yǔ)言分支循環(huán)其嵌套內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語(yǔ)言中如何獲取函數(shù)內(nèi)成員的值你知道嗎

    C語(yǔ)言中如何獲取函數(shù)內(nèi)成員的值你知道嗎

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言中如何獲取函數(shù)內(nèi)成員的值的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2022-03-03
  • Visual C++ 常用數(shù)據(jù)類(lèi)型轉(zhuǎn)換方法詳解

    Visual C++ 常用數(shù)據(jù)類(lèi)型轉(zhuǎn)換方法詳解

    本文純粹是總結(jié)一下有關(guān)類(lèi)型轉(zhuǎn)換的貼子,需要的朋友可以參考下
    2017-06-06
  • 解析wprintf 中使用%I64d格式化輸出LONGLONG的詳細(xì)介紹

    解析wprintf 中使用%I64d格式化輸出LONGLONG的詳細(xì)介紹

    本篇文章是對(duì)wprintf 中使用%I64d格式化輸出LONGLONG進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • C++?IO設(shè)備讀寫(xiě)功能實(shí)現(xiàn)詳解

    C++?IO設(shè)備讀寫(xiě)功能實(shí)現(xiàn)詳解

    C++的文件IO(Input,Output)操作就是指對(duì)文件進(jìn)行讀寫(xiě)(輸入與輸出)的操作。輸入就是從磁盤(pán)上的文件中讀取內(nèi)容到內(nèi)存中。輸出就是將內(nèi)存中的數(shù)據(jù)內(nèi)容輸出或者說(shuō)寫(xiě)入到磁盤(pán)的文件中,這篇文章主要介紹了C++?IO設(shè)備讀寫(xiě)功能實(shí)現(xiàn)
    2022-11-11
  • C++實(shí)現(xiàn)的鏈表類(lèi)實(shí)例

    C++實(shí)現(xiàn)的鏈表類(lèi)實(shí)例

    這篇文章主要介紹了C++實(shí)現(xiàn)的鏈表類(lèi),以完整實(shí)例分析了C++實(shí)現(xiàn)鏈表類(lèi)的定義、插入、刪除、遍歷、統(tǒng)計(jì)等相關(guān)技巧,需要的朋友可以參考下
    2015-06-06
  • c++ cin 作為while條件(詳解)

    c++ cin 作為while條件(詳解)

    下面小編就為大家?guī)?lái)一篇c++ cin 作為while條件(詳解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-05-05
  • C++實(shí)現(xiàn)打印兩個(gè)有序鏈表公共部分的方法

    C++實(shí)現(xiàn)打印兩個(gè)有序鏈表公共部分的方法

    這篇文章主要介紹了C++實(shí)現(xiàn)打印兩個(gè)有序鏈表公共部分的方法,涉及C++針對(duì)有序鏈表的簡(jiǎn)單遍歷、比較相關(guān)操作技巧,需要的朋友可以參考下
    2017-05-05
  • C++ 中this指針的用途詳解

    C++ 中this指針的用途詳解

    這篇文章主要給大家介紹了關(guān)于C++ 中this指針的用途,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用C++具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-09-09
  • OpenCV邊緣提取算法流程的實(shí)現(xiàn)(附DEMO)

    OpenCV邊緣提取算法流程的實(shí)現(xiàn)(附DEMO)

    本文主要介紹了OpenCV邊緣提取算法流程的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • 詳解C++設(shè)計(jì)模式編程中策略模式的優(yōu)缺點(diǎn)及實(shí)現(xiàn)

    詳解C++設(shè)計(jì)模式編程中策略模式的優(yōu)缺點(diǎn)及實(shí)現(xiàn)

    這篇文章主要介紹了C++設(shè)計(jì)模式編程中策略模式的優(yōu)缺點(diǎn)及實(shí)現(xiàn),文中討論了策略模式中設(shè)計(jì)抽象接口的繼承和組合之間的區(qū)別,需要的朋友可以參考下
    2016-03-03

最新評(píng)論