解密C语言选择结构:掌握条件语句与分支逻辑的利器

引言

C语⾔是结构化的程序设计语⾔,这⾥的结构指的是顺序结构、选择结构、循环结构。为什么有着三种结构呢,大家其实可以想象一下,生活中的绝大数事情都可以抽象着三种结构,而我们今天要给大家介绍的就是三大结构之一——选择结构

选择结构要求程序员指定一个或多个要评估或测试的条件,以及条件为真时要执行的语句(必需的)和条件为假时要执行的语句(可选的)。它的流程图大致如下:

1. 逻辑运算符

在讲解什么是选择结构前,我们要先了解一些C语言常见的逻辑运算符。

1.1 逻辑取反运算符

逻辑取反运算符的形式特别简单,只需要在需要进行取反操作的变量前+!:

!(变量名)

假设有变量a,它的取反规则如下:

1.2 与运算符

在C语言中,并不支持数学上的且,而是由一个运算符&&代替的。比如说数学上的0<x<10写成C语言的形式就是x>0&&x<10。

假设有两个变量a,b,与运算符的运算规则如下:

1.3 或运算符

在C语言中,或者也有专门的运算符表示——||

假设有两个变量a,b,或运算符的运算规则如下:

2. if......else语句

2.1 if语句

if语句是最简单选择结构语法之一,他的语法结构如下:

if ( 表达式 )语句

表达式成⽴(为真),则语句执⾏,表达式不成⽴(为假),则语句不执⾏。

C语言特别规定:非零为真,零为假。

例⼦:输⼊⼀个整数,判断是否为奇数,如果是奇数打印是奇数

#include<stdio.h>
int main()
{int num = 0;scanf("%d", &num);if (num % 2 == 1)printf("%d 是奇数\n", num);return 0;
}

  • 首先输入一个值(num),然后进入if语句判断,如果num%2等于1,条件就为真,就会打印;反之,条件为假,就不会进入打印。

  • 特别注意:C语言中判断是否相等的运算符是==,=是赋值符号。

2.2 else

我们继续以上面例子为列,如果⼀个数不是奇数,那就是偶数了,如果任意⼀个整数,我们要清楚的判断是奇数还是偶数怎么表⽰呢?这⾥就需要 if...else... 语句了,语法形式如下:

if ( 表达式 )语句1else语句2

所以上面的例子可以改写成如下代码:

#include<stdio.h>
int main()
{int num = 0;scanf("%d", &num);if (num % 2 == 1)printf("%d 是奇数\n", num);elseprintf("%d 是偶数\n", num);return 0;
}

  • 默认在 if 和 else 语句中默认都只控制⼀条语句

2.3 多个if else的使用

if else 语句也可以多个同时使用,构成多个分支,形式如下:

if(判断条件1){语句块1} else if(判断条件2){语句块2}else if(判断条件3){语句块3}else if(判断条件m){语句块m}else{语句块n}

意思是,从上到下依次检测判断条件,当某个判断条件成立时,则执行其对应的语句块,然后跳到整个 if else 语句之外继续执行其他代码。如果所有判断条件都不成立,则执行语句块n,然后继续执行后续代码。

也就是说,一旦遇到能够成立的判断条件,则不再执行其他的语句块,所以最终只能有一个语句块被执行。

我们以下面这段代码举个例子:

#include<stdio.h>int main()
{int age = 0;scanf("%d", &age);if (age > 0 && age < 18) {printf("少年\n");}else if (age >= 18 && age < 30) {printf("青年\n");}else if (age >= 30 && age < 45) {printf("壮年\n");}else if (age >= 45 && age < 55) {printf("中年\n");}else if (age >= 55 && age < 75) {printf("老年\n");}else {printf("老寿星\n");}return 0;
}

假设我们输入的是40,输出:

2.4 if else的嵌套

if else也能嵌套使用,也就是说if执行的语句中也可以包含if else语句。我们用判断三角形来具体说明这个问题:

#include <stdio.h>
int main()
{int a, b, c;while(scanf("%d%d%d", &a, &b, &c)==3){if (a + b > c && a + c > b && b + c > a) {if (a == b && b == c) {printf("是一个等边三角形");}else if (a == b || a == c || b == c) {printf("是一个等腰三角形");}else if (a * a + b * b == c * c || a * a + c * c == b * b || b * b + c * c == a * a) {printf("是一个直角三角形");}else {printf("是一个普通三角形");}}else {printf("由%d,%d,%d三边组成的不是三角形", a, b, c);}}return 0;
}

2.5 悬空的else

在书写if....else语句时最好每一条语句后面都加上大括号

至于为什么,我们可以以下面这段代码举例

#include<stdio.h>
int main()
{int a = 0;int b = 2;if (a == 1)if (b == 2)printf("hehe\n");elseprintf("haha\n");return 0;
}//输出什么???

输出结果:

为什么会什么结果都没有输出呢?

这就是悬空 else 的问题,如果有多个 if 和 else ,可以记住这样⼀条规则, else 总是跟最接近的 if 匹配。最下面的else其实是与if(b==2)这条语句配对的,而不是与if(a==1)配对,当a等于0,自然不会进入任何语句。

3. switch语句

在我们学习多个lf else语句时候就会会发现,如果条件多的话,整个选择结构就会变得很冗杂,所以C语言为了解决这个问题引入了switch,switch 是另外一种选择结构的语句,用来代替简单的、拥有多个分支的 if else 语句。

比如说下面这段代码就会显得十分冗余

int main()
{int day = 0;scanf("%d", day);if(day == 1)printf("星期一\n");else if(day == 2)printf("星期二\n");else if (day == 3)printf("星期三\n");else if (day == 4)printf("星期四\n");else if (day == 5)printf("星期五\n");else if (day == 6)printf("星期六\n");elseprintf("星期天\n");return 0;
}

3.1 switch的基本规则

switch的语法如下:

switch (expression) {case value1: statementcase value2: statementdefault: statement}

switch语句必须遵循下面的规则:

  1. switch语句中的括号是一个常量表达式,必须是一个整型或枚举类型。

  2. 在一个 switch 中可以有任意数量的 case 语句。每个 case 后跟一个要比较的值和一个冒号。

3.2 break的重要性

学习完switch的语法之后,然后我们可以将最开始的例子改造

int main()
{int day = 0;scanf("%d", &day);switch (day){case 1:printf("星期一\n");case 2:printf("星期二\n");case 3:printf("星期三\n");case 4:printf("星期四\n");case 5:printf("星期五\n");case 6:printf("星期六\n");case 7:printf("星期天\n");}return 0;
}

但是当我们一运行代码就会发现问题:

为什么输入1反而后续的结果都输出了呢?

原因是 switch 语句也是分⽀效果的,只有在 switch 语句中使⽤ break 才能在跳出 switch 语句,如果某⼀个 case 语句的后边没有 break 语句,代码会继续玩下执⾏,有可能执⾏其他 case语句中的代码,直到遇到 break 语句或者 switch 语句结束。

所以在 switch 语句中 break 语句是⾮常重要的,能实现真正的分⽀效果。

当然, break 也不是每个 case 语句都得有,这就得根据实际情况来看了。

改造代码后;

int main()
{int day = 0;scanf("%d", &day);switch (day){case 1:printf("星期一\n");break;case 2:printf("星期二\n");break;case 3:printf("星期三\n");break;case 4:printf("星期四\n");break;case 5:printf("星期五\n");break;case 6:printf("星期六\n");break;case 7:printf("星期天\n");break;}return 0;
}

3.3 default的使用

在使⽤ switch 语句的时候,我们经常可能遇到⼀种情况,⽐如 switch 后的表达式中的值⽆法匹配代码中的 case 语句的时候,这时候要不就不做处理,要不就得在 switch 语句中加⼊default ⼦句。

其语法如下:

switch (expression) {case value1: statementcase value2: statementdefault: statement}

  • switch 后边的 expression 的结果不是 value1 ,也不是 value2 的时候,就会执⾏default ⼦句。

就⽐如前⾯做的打印星期的练习,如果 day 的输⼊不是1~7的值,如果我们要提⽰:输⼊错误,则可以这样完成代码:

#include<stdio.h>
int main()
{int day = 0;scanf("%d", &day);switch (day){case 1:printf("星期一\n");break;case 2:printf("星期二\n");break;case 3:printf("星期三\n");break;case 4:printf("星期四\n");break;case 5:printf("星期五\n");break;case 6:printf("星期六\n");break;case 7:printf("星期天\n");break;default :printf("输入错误\n");break;}return 0;
}

  • 在 switch 语句中 case 语句和 default 语句是没有顺序要求的,只要你的顺序是满⾜实际需求的就可以。不过我们通常是把 default ⼦句放在最后处理的。

4. 综合练习

4.1 题目一

输入三个整数x,y,z,请把这三个数由小到大输出。

#include <stdio.h>
int main()
{int x, y, z, t;printf("请输入三个数字:\n");scanf("%d%d%d", &x, &y, &z);if (x > y) { /*交换x,y的值*/t = x; x = y; y = t;}if (x > z) { /*交换x,z的值*/t = z; z = x; x = t;}if (y > z) { /*交换z,y的值*/t = y; y = z; z = t;}printf("从小到大排序: %d %d %d\n", x, y, z);return 0;
}

4.2 题目二

输入某年某月某日,判断这一天是这一年的第几天?

#include <stdio.h>
int main()
{int day, month, year, sum, leap;printf("请输入年、月、日,格式为:年,月,日(2015,12,10)\n");scanf("%d,%d,%d", &year, &month, &day);  // 格式为:2015,12,10switch (month) // 先计算某月以前月份的总天数{case 1:sum = 0; break;case 2:sum = 31; break;case 3:sum = 59; break;case 4:sum = 90;break;case 5:sum = 120;break;case 6:sum = 151;break;case 7:sum = 181; break;case 8:sum = 212; break;case 9:sum = 243;break;case 10:sum = 273; break;case 11:sum = 304; break;case 12:sum = 334; break;default:printf("输入错误\n"); break;}sum = sum + day; // 再加上某天的天数if (year % 400 == 0 || (year % 4 == 0 && year % 100 != 0)) {// 判断是不是闰年leap = 1;}else {leap = 0;}if (leap == 1 && month > 2) { // *如果是闰年且月份大于2,总天数应该加一天sum++;}printf("这是这一年的第 %d 天。", sum);printf("\n");return 0;
}

文章转载自:Betty’sSweet

原文链接:https://www.cnblogs.com/bett/p/18028037

体验地址:引迈 - JNPF快速开发平台_低代码开发平台_零代码开发平台_流程设计器_表单引擎_工作流引擎_软件架构

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/697867.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Jenkins 中部署Nodejs插件并使用,并构建前端项目(3)

遇到多个版本nodeJS需要构建的时候 1、第一种就是一个配置安装&#xff0c;然后进行选中配置 2、第二种就是插件&#xff1a;nvm-wrapper&#xff0c;我们还是选用NodeJS插件&#xff1a; &#xff08;1&#xff09;可以加载任意npmrc文件&#xff1b; &#xff08;2&#x…

鸿蒙NEXT出现有前途吗?是否会和安卓、IOS开发历程一样?

只要有手机操作系统这玩意存在&#xff0c;一定是需要原生开发人员的&#xff0c;但随着独立操作系统越来越多的话&#xff0c;混合App开发可能是个“万能解决方案”。 2024年&#xff0c;在中国&#xff0c;被各大媒体和开发者称为“鸿蒙元年”。 在2023年底就有业内人士透露…

常见锁策略,CAS,synchrodized原理讲解

&#x1f3a5; 个人主页&#xff1a;Dikz12&#x1f4d5;格言&#xff1a;那些在暗处执拗生长的花&#xff0c;终有一日会馥郁传香欢迎大家&#x1f44d;点赞✍评论⭐收藏 目录 常见锁策略 乐观锁和悲观锁 轻量级锁和重量级锁 自旋锁和挂起等待锁 读写锁 公平锁和非公平锁…

Transformer 架构—Encoder-Decoder

文章目录 前言 一、Encoder 家族 1. BERT 2. DistilBERT 3. RoBERTa 4. XML 5. XML-RoBERTa 6. ALBERT 7. ELECTRA 8. DeBERTa 二、Decoder 家族 1. GPT 2. GPT-2 3. CTRL 4. GPT-3 5. GPT-Neo / GPT-J-6B 三、Encoder-Decoder 家族 1. T5 2. BART 3. M2M-100 4. BigBird 前言 …

每日五道java面试题之spring篇(三)

目录&#xff1a; 第一题 ApplicationContext和BeanFactory有什么区别&#xff1f;第二题 Spring中的事务是如何实现的&#xff1f;第三题 Spring中什么时候Transactional会失效&#xff1f;第四题 Spring容器启动流程是怎样的&#xff1f;第五题 Spring Boot、Spring MVC 和 S…

Sip网络广播号角,sip广播系统公共广播系统有源喇叭

Sip网络广播号角&#xff0c;sip广播系统公共广播系统有源喇叭 SV-7044VP网络有源喇叭&#xff0c;具有10/100M以太网接口&#xff0c;内置高品质扬声器&#xff0c;通过自带放大器播放网络音频&#xff0c;扬声器输出功率高达30W&#xff0c;还支持设置最多10个组播优先区域&…

js如何抛异常,抛自定义的异常

js如何抛异常,抛自定义的异常 最简单的自定义异常 throw "hello" 来自chrome123的控制台的测试 throw "hello" VM209:1 Uncaught hello &#xff08;匿名&#xff09; VM209:1 try{ throw "hello";}catch(e){console.log(e);} VM338:1 hello…

nuxt项目搭建

1.先下载nuxt脚手架 yarn create nuxt-app <项目名>&#xff0c;记得安装完项目&#xff0c;npm i,下载node包 目录介绍 components 存放组件分别是头部&#xff08;包含导航&#xff09;和底部 layouts 页面布局&#xff0c;实现一个页面整体架构规则&#xff0c;头…

XTuner InternLM-Chat 个人小助手认知微调实践

要解决的问题&#xff1a; 如何让模型知道自己做什么&#xff0c;是什么样身份。是谁创建了他&#xff01;&#xff01;&#xff01; 概述 目标&#xff1a;通过微调&#xff0c;帮助模型认清了解对自己身份弟位 方式&#xff1a;使用XTuner进行微调 微调前&#xff08;回答…

精致女童时尚穿搭~你想要的我都有哦

不论是版型还是颜色 都绝绝子的一件轻薄外套 整件看着干净利落有设计感 两侧按扣式口袋超级实用的 穿着透气不闷热 搭配各种风格的裤子都一绝

【安卓基础5】中级控件

&#x1f3c6;作者简介&#xff1a;|康有为| &#xff0c;大四在读&#xff0c;目前在小米安卓实习&#xff0c;毕业入职 &#x1f3c6;本文收录于 安卓学习大全持续更新中&#xff0c;欢迎关注 &#x1f3c6;安卓学习资料推荐&#xff1a; 视频&#xff1a;b站搜动脑学院 视频…

无线听觉新体验:南卡、韶音、墨觉骨传导耳机综合评测

作为一个资深的跑步爱好者&#xff0c;我几乎离不开音乐的陪伴。不知道大家有没有同感&#xff0c;有时候一首歌曲就是我坚持下去的动力&#xff0c;尤其是在那段艰难的跑步时刻。但是找到一款既能让我在运动中自由呼吸、又能提供优质音乐体验的耳机&#xff0c;并不是一件容易…

C#,动态规划(DP)丢鸡蛋问题(Egg Dropping Puzzle)的三种算法与源代码

1 扔鸡蛋问题 动态规划&#xff08;Dynamic Programming&#xff0c;DP&#xff09;是运筹学的一个分支&#xff0c;是求解决策过程最优化的过程。20世纪50年代初&#xff0c;美国数学家贝尔曼&#xff08;R.Bellman&#xff09;等人在研究多阶段决策过程的优化问题时&#xf…

船舶制造5G智能工厂数字孪生可视化平台,推进船舶行业数字化转型

船舶制造5G智能工厂数字孪生可视化平台&#xff0c;推进船舶行业数字化转型。随着数字化时代的到来&#xff0c;船舶行业正面临着前所未有的机遇与挑战。为了适应这一变革&#xff0c;船舶制造企业需要加快数字化转型的步伐&#xff0c;提高生产效率、降低成本并增强市场竞争力…

电气机械5G智能工厂数字孪生可视化平台,推进电气机械行业数字化转型

电气机械5G智能工厂数字孪生可视化平台&#xff0c;推进电气机械行业数字化转型。随着科技的不断发展&#xff0c;数字化转型已经成为各行各业发展的重要趋势。电气机械行业作为传统制造业的重要组成部分&#xff0c;也面临着数字化转型的挑战和机遇。为了更好地推进电气机械行…

就业月薪14K!两年后涨到25K! 考研失败后,这个95年小哥哥成功转行软件测试,人生开挂了!

01 考研连续失败 因为没有特别明确的职业规划&#xff0c;加上内心的学历崇拜情节。大学毕业后&#xff0c;我没有选择参加工作&#xff0c;而是毅然选择了加入考研大军。 备考的日子紧张有序&#xff0c;我也一直在题海里废寝忘食的遨游&#xff0c;本以为能顺顺当当地考上自…

Windows环境下查看磁盘层级占用空间的解决方案

大家好,我是爱编程的喵喵。双985硕士毕业,现担任全栈工程师一职,热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。现为CSDN博客专家、人工智能领域优质创作者。喜欢通过博客创作的方式对所学的…

生产环境下,应用模式部署flink任务,通过hdfs提交

前言 通过通过yarn.provided.lib.dirs配置选项指定位置&#xff0c;将flink的依赖上传到hdfs文件管理系统 1. 实践 &#xff08;1&#xff09;生产集群为cdh集群&#xff0c;从cm上下载配置文件&#xff0c;设置环境 export HADOOP_CONF_DIR/home/conf/auth export HADOOP_CL…

vue2和vue3 setup beforecreate create生命周期时间比较

创建一个vue程序&#xff0c;vue3可以兼容Vue2的写法&#xff0c;很流畅完全没问题 写了一个vue3组件 <template><div></div> </template><script lang"ts"> import {onMounted} from vue export default{data(){return {}},beforeCr…

解决SpringAMQP工作队列模型程序报错:WARN 48068:Failed to declare queue: simple.queue

这里写目录标题 1.运行环境2.报错信息3.解决方案4.查看解决之后的效果 1.运行环境 使用docker运行了RabbitMQ的服务器&#xff1a; 在idea中导入springAMQP的jar包&#xff0c;分别编写了子模块生产者publisher&#xff0c;消费者consumer&#xff1a; 1.在publisher中运行测试…