你是真的“C”——深度提炼分支与循环语句的“精髓”

news/2024/11/27 21:57:01/

深度提炼分支与循环语句+goto语句的“精髓”😎

  • 前言🙌
  • 一、分支与循环语句具体是什么?🙌
    • 1、分支语句🙌
      • if语句中的精髓😍
      • switch语句中的精髓😍
    • 2、循环语句🙌
      • while循环语句中的精髓😍
      • for循环语句中的精髓😍
      • do...while()循环语句中的精髓 😍
    • goto语句🙌
  • 分支与循环语句相关经典练习💞
      • 1.计算 n的阶乘。🙌
      • 2.计算 1!+2!+3!+……+10!🙌
      • 3. 在一个有序数组中查找具体的某个数字n。(讲解二分查找)🙌
      • 4. 编写代码,演示多个字符从两端移动,向中间汇聚。🙌
      • 5. 编写代码实现,模拟用户登录情景,并且只能登录三次。(只允许输入三次密码,如果密码正确则提示登录成,如果三次均输入错误,则退出程序。🙌
      • 乘法口诀表-在屏幕上输出9 * 9乘法口诀表🙌
      • 求10 个整数中最大值🙌
      • 算1 / 1 - 1 / 2 + 1 / 3 - 1 / 4 + 1 / 5 …… + 1 / 99 - 1 / 100 的值,打印出结果🙌
      • 编写程序数一下 1到 100 的所有整数中出现多少个数字9🙌
      • 完成猜数字游戏🙌
  • 总结撒花💞

   哈喽!😄各位CSDN的uu们,我是你的博客好友小梦,希望我的文章可以给您带来一定的帮助,话不多说,文章推上!欢迎大家在评论区唠嗑指正,觉得好的话别忘了一键三连哦!😘

前言🙌

    哈喽各位友友们😊,我今天又学到了很多有趣的知识现在迫不及待的想和大家分享一下!😘我仅已此文,手把手带领大家**学习C语言中分支与循环语句的相关知识!都是精华内容,可不要错过哟!!!😍😍😍

一、分支与循环语句具体是什么?🙌

具体可以细分为以下几类💞

  • 分支语句
    if
    switch

  • 循环语句
    while
    for
    do while

  • goto语句

1、分支语句🙌

if语句中的精髓😍

  • 在if的()中是我们的条件表达式,无论是if还是循环等,在判断表达式中都遵循这一条铁律:0表示假,非0表示真。
  • else的匹配:else是和它离的最近的if匹配的。
  • 当我们的执行语句只有一句时,我们可以省略大括号,当有多条语句,则不可以省略,这里用代码辅助大家分析:
if (a > 18)printf("未成年");elseprintf("成年");

switch语句中的精髓😍

  • 在switch语句中,我们没办法直接实现分支,搭配break使用才能实现真正的分支
  • break语句 的实际效果是把语句列表划分为不同的分支部分。
  • 在最后一个case语句中,加不加break都没有什么本质上的差别。但为了养成编程好习惯,在最后一个 case 语句的后面加上一条 break语句。(之所以这么写是可以避免出现在以前的最后一个 case 语句后面忘了添加 break语句)。
  • 当 switch 表达式的值并不匹配所有 case 标签的值时,这个 default 子句后面的语句就会执行。
  • 每个switch语句中只能出现一条default子句。但是它可以出现在语句列表的任何位置,而且语句流会像执行一个case标签一样执行default子句。
  • 在每个 switch 语句中都放一条default子句是个好习惯,甚至可以在后边再加一个 break 。

2、循环语句🙌

while循环语句中的精髓😍

  • while语句中,你可能会经常看到break和continue关键字。
  • 在循环中只要遇到break,就停止后期的所有的循环,直接终止循环。所以:while中的break是用于永久终止循环的。
  • continue在while循环中的作用就是:continue是用于终止本次循环的,也就是本次循环中continue后边的代码不会再执行。这里用代码辅助大家理解一下
#include <stdio.h>
int main()
{int i = 1;while(i<=10){i = i+1;if(i == 5)continue;printf("%d ", i);}return 0;
}

大家可以思考一下这个代码的执行结果是什么?就能了解continue的玄妙之处,当i == 5的时候,会跳过下面的代码直接回到while的判断表达式。

for循环语句中的精髓😍

  • for循环相比于while循环,有形式上的优势,它把初始化表达式、判断表达式、调整表达式都集中在一起,方便代码的阅读性和排错性。所以,for循环的风格更胜一筹;for循环使用的频率也最高。在这里,小梦也更推荐for循环使用。但具体还是要看具体业务需求来选择使用哪种循环来编写,哪种方便用哪种。
  • 在for循环中,同样有break,continue关键字。他们的意义都是相同的,但是也有所差异。可能在使用continue的时候,在while中跳过了调整表达式而造成死循环出现,而在for循环中就可以规避这个风险,因为for循环三个表达式都在前面括号中。
#include <stdio.h>
int main()
{int i = 1;while(i<=10){if(i == 5)continue;printf("%d ", i);i = i+1;}return 0;
}

上面这个代码的输出结果是1 2 3 4死循环

  • 建议尽量不要在for 循环体内修改循环变量,防止 for 循环失去控制。
  • 建议for语句的循环控制变量的取值采用“前闭后开区间”写法。这里用代码辅助大家理解一下
int i = 0;
//前闭后开的写法
for(i=0; i<10; i++)
{}

do…while()循环语句中的精髓 😍

  • do语句的特点是:循环至少执行一次,使用的场景有限,所以不是经常使用。
  • 在do while循环中也存在着break和continue,和在其他循环中的意义一样。

goto语句🙌

关于goto语句的相关知识学习,具体解法和详细实现思路在我之前的链接: 你你是真的“C”——goto语句设计一个关机程序博客中有。点击即可查看学习啦。😍

分支与循环语句相关经典练习💞

1.计算 n的阶乘。🙌

#define _CRT_SECURE_NO_WARNINGS 1//vs编译器才需要这句代码
#include<stdio.h>
int main()
{int n = 0;//输入scanf("%d", &n);//计算n的阶乘int i = 0;int ret = 1;for (i = 1; i <= n; i++){ret *= i;}printf("%d\n", ret);return 0;
}

2.计算 1!+2!+3!+……+10!🙌

#define _CRT_SECURE_NO_WARNINGS 1//vs编译器才需要这句代码
#include<stdio.h>
int main()
{int n = 0;//输入//计算n的阶乘int i = 0;int ret = 1;int sum = 0;//1+2+6 = 9for (n = 1; n <= 10; n++){ret *= n;sum += ret;}printf("%d\n", sum);return 0;
}

3. 在一个有序数组中查找具体的某个数字n。(讲解二分查找)🙌

这道题的具体解法和详细实现思路在我之前的链接: 你是真的“C”——C语言实现冒泡排序+折半查找(二分查找算法)博客中有。点击即可查看啦。😍

4. 编写代码,演示多个字符从两端移动,向中间汇聚。🙌

#define _CRT_SECURE_NO_WARNINGS 1//vs编译器才需要这句代码
#include<stdio.h>
#include <string.h>
#include <windows.h>
int main()
{char arr1[] = "welcome to bit!!!!";char arr2[] = "******************";int left = 0;int right = strlen(arr1)-1;while (left<=right){arr2[left] = arr1[left];arr2[right] = arr1[right];printf("%s\n", arr2);Sleep(1000);system("cls");left++;right--;}printf("%s\n", arr2);return 0;
}

5. 编写代码实现,模拟用户登录情景,并且只能登录三次。(只允许输入三次密码,如果密码正确则提示登录成,如果三次均输入错误,则退出程序。🙌

#define _CRT_SECURE_NO_WARNINGS 1//vs编译器才需要这句代码
#include<stdio.h>
//假设正确的密码是:"123456"
int main()
{int i = 0;char password[20] = { 0 };int flag = 0;for (i = 0; i < 3; i++){printf("请输入密码:>");scanf("%s", password);//判断if (strcmp(password, "123456") == 0){flag = 1;printf("密码正确\n");break;}else{printf("密码错误\n");}}if (flag == 0)printf("三次密码均错误,退出程序\n");return 0;
}

乘法口诀表-在屏幕上输出9 * 9乘法口诀表🙌

int main()
{int n = 0;scanf("%d", &n);for (int i = 1; i <= n; i++){for (int j = 1; j <= i; j++){printf("%d * %d =%-2d ", j, i, i * j);}printf("\n");}return 0;
}

求10 个整数中最大值🙌

//错误代码,这个代码忽略了输入十个负数的情况,这样会使得最大值为0.答案错误。这里必须是要先让最大值max赋值为第一个元素的值,
// 然后再让其它元素和一一比较
//int main()
//{
//	int n = 0;
//	int max = 0;
//	for (int i = 0; i < 10; i++)
//	{
//		scanf("%d", &n);
//		if (n > max)
//		{
//			max = n;
//		}
//	}
//	printf("%d", max);
//
//	return 0;
//}
//正确代码
int main()
{int arr[10] = { 0 };int i = 0;int max = 0;for (i = 0; i < 10; i++){scanf("%d", &arr[i]);}//max = arr[0];for (i = 1; i < 10; i++){if (arr[i] > max)max = arr[i];}printf("max = %d\n", max);return 0;
}

算1 / 1 - 1 / 2 + 1 / 3 - 1 / 4 + 1 / 5 …… + 1 / 99 - 1 / 100 的值,打印出结果🙌

int main()
{double sum = 0;int flag = 1;for (int i = 1; i <= 100; i++){sum += (1.0 / i) * flag;flag = -flag;}printf("%lf", sum);
}

编写程序数一下 1到 100 的所有整数中出现多少个数字9🙌

//错误代码,只算了99中一个9
//int main()
//{
//	int count = 0;
//	for (int i = 1; i <= 100; i++)
//	{
//		if (i % 10 == 9 || (i / 10) % 10 == 9)
//		{
//			count++;
//		}
//	}
//	printf("%d", count);
//	return 0;
//}
//正确代码:
int main()
{int i = 0;int count = 0;for (i = 1; i <= 100; i++){if (i % 10 == 9)count++;if (i / 10 == 9)count++;}printf("%d\n", count);return 0;
}

这题需要注意的是99中有两个数字9。一开始我就做错了哈哈哈。

完成猜数字游戏🙌

这道题的具体解法和详细实现思路在我之前的链接: 你是真的“C”——C语言实现猜数字游戏博客中有。点击即可查看学习啦。😍

总结撒花💞

    上述就是我今天分享的主要内容啦,你学会了吗?如果我写的有什么的不好之处或者不足之处,请在文章下方给出你宝贵的意见😊。如果觉得我写的好的话请点个赞赞和关注哦~😘😘😘


http://www.ppmy.cn/news/10959.html

相关文章

[ 数据结构 ] 弗洛伊德算法(Floyd)--------最短路径问题

0 Floyd算法介绍 和 Dijkstra 算法一样&#xff0c;弗洛伊德(Floyd)算法也是一种用于寻找给定的加权图中顶点间最短路径的算法。该算法名称以创始人之一、1978 年图灵奖获得者、斯坦福大学计算机科学系教授罗伯特弗洛伊德命名弗洛伊德算法(Floyd)计算图中各个顶点之间的最短路…

C#编程遇到的问题合集(2023.1.9)

文章目录1.Partial类2.MessageBox的用法3.Static类和Static变量4.SubString函数用法5.读取指定文件内容的一般格式6.二进制字符串转换为十进制数字7.给窗口添加任务栏图标8.给窗口设置最大化和最小化按钮1.Partial类 Partial类的意思是定义一个类的一部分。也就是说&#xff0…

异步path怎么约?

异步path怎么约? 在design里往往会有一些特殊需求,例如约束两个异步clock之间的path,而异步path对于工具来说往往是不做任何约束的,那么我们应该怎么去对异步clock之间的path做约束呢? 异步clock 异步clock可以通过两个办法来约束: 1、set_clock_group 2、set_false_p…

汤姆斯的天堂梦(C++,Dijkstra)

题目描述 汤姆斯生活在一个等级为 000 的星球上。那里的环境极其恶劣&#xff0c;每天 121212 小时的工作和成堆的垃圾让人忍无可忍。他向往着等级为 NNN 的星球上天堂般的生活。 有一些航班将人从低等级的星球送上高一级的星球&#xff0c;有时需要向驾驶员支付一定金额的费…

EEG论文阅读和分析:《Differential entropy feature for EEG-based emotion classification》

论文阅读《Differential entropy feature for EEG-based emotion classification》 论文的核心是提出差分熵作为特征&#xff0c;并且对差分差分熵和比例差分熵等特征进行对比研究。 算法流程步骤&#xff1a; 采样过程&#xff1a; A.预处理 根据受试者的压力反应&#xf…

指针详解——高级指针的解析及应用

目录 &#x1f411;指针的初步了解 &#x1f402;指针的深入认识 &#x1f99b;1.指针数组 &#x1f400;指针数组的介绍 &#x1f400;指针数组的用法介绍 &#x1f42b;2.数组指针 &#x1f98c;数组指针的介绍以及使用 &#x1f9ae;3.函数指针 &#x1f408;函数指针的介绍…

【数据结构与算法】——第六章:图

文章目录1、图的定义1.1 图的其他定义1.2 图的顶点与边之间的关系1.3 连通图相关术语2、图的存储结构2.1 邻接矩阵2.2 邻接表3、图的遍历3.1 深度优先遍历3.2 广度优先遍历4、最小生成树4.1 普利姆算法(Prim)4.2 克鲁斯卡尔(kruskal)5、最短路径5.1 迪杰斯特拉(Dijkstra)算法5.…

【图的存储】

更好的阅读体验\color{red}{更好的阅读体验}更好的阅读体验 文章目录1. 邻接矩阵2. 边集数组3. 邻接表4. 链式邻接表5. 链式前向星总结1. 邻接矩阵 思想&#xff1a; 利用二维数组 g[N][N] 存储所有的点到点的权值。其中 N 为点的数量&#xff0c;g[i][j] 表示点 i 到点 j 的权…