C语言_3 选择结构

简介: 是翁恺老师的132p C语言程序设计网课。

3.1.1 做判断

if条件判断

    if(条件){
        要执行的语句,只有条件成立时才会执行
    }

3.1.2 判断的条件

计算两个值之间的关系,叫做关系运算
==判断相等
!=不相等
还有>;>=;<;<=,当两个值的关系复合这些关系运算符的预期时,关系运算的结果为整数1,否则为整数0

printf("%d\n",5>3);
printf("%d\n",5==3);

输出结果:1(换行)0
所有关系运算符的优先级都比算数运算低,比赋值运算高
(编程语言都是可以人为验证的)
int r=a>0;先判断a是否>0,再把0/1的值赋给r
==!=优先级比其他的低
连续的关系运算是从左到右进行的
5>3==6>41==1成立
6>5>41>4不成立

3.1.3 找零计算器

flowchat
st=>start: 开始
i1=>inputoutput: 输入购买的金额
i2=>inputoutput: 输入支付的票面
o1=>operation: 计算找零
c=>condition: 判断余额是否充足
o2=>inputoutput: 打印找零
o3=>inputoutput: 告知用户余额不足以购买
e=>end: 结束

st->i1->i2->o1->c
c(yes)->o2->e
c(no)->o3->e
    //初始化
    int price=0;
    int bill=0;
    //读入金额和票面
    printf("请输入金额:");
    scanf("%d",&price);
    printf("请输入票面:");
    scanf("%d",&bill);
    //计算找零

//是(单行)注释,把程序分成了三个部分:初始化,读入金额和票面,计算并打印找零;
c99可以,ASCII不支持
comment对程序的功能没有任何影响,但是往往能使程序更容易被人类读者理解。
/* */中间可以有多行注释。

3.1.4 否则的话

比如刚刚的找零计算器:金额<票面
else{ }if的补集
输入两数,找最大者:
方案一

    int a,b;
    printf("请输入两个整数:");
    scanf("%d %d",&a,&b);
    int max=0;
    if(a>b)max=a;
    else max=b;
    printf("大的那个是%d\n",max);

方案二

    int a,b;
    printf("请输入两个整数:");
    scanf("%d %d",&a,&b);
    int max=b;
    if(a>b)max=a;
    printf("大的那个是%d\n",max);

可以对比两种方案,方案二绝绝子

3.1.5 再探if语句

if语句可以不加大括号

if(a>b)
    max=a;

If这行结束并没有语句结束的标志;而后面的赋值语句写在下一行且缩进了,结束时有“;”。这表明这条赋值语句是if语句的一部分,if语句拥有和控制这条赋值语句,决定他是否要被执行。
就是说,没有大括号,后面一句话是有效的,也只能这一句是有效的(包含在if里)。

3.2.1 嵌套的if-else

找三个数中的最大数:先比较两个数谁更大,较大的再和c比较。

if(a>b)
{
    if(a>c)max=a;
    else max=c;
}
else
{
    if(b>c)max=b;
    else max=c;
}

3.2.2 级联的if-else if

如分段函数。这时可以用级联的else if 表达多种情况
每个else是前一个if的else,但是前面两个都不满足的话就只剩下第三个了

flowchat
st=>start: 开始
i=>inputoutput: 输入
o=>inputoutput: 输出
c1=>condition: 是否满足条件1
c2=>condition: 是否满足条件2
o1=>inputoutput: 输出条件1
o2=>inputoutput: 输出条件2
o3=>inputoutput: 输出条件3
en=>end: 结束
st->i->c1
c1(yes)->o1->en
c1(no)->c2
c2(yes)->o2->en
c2(no)->o3->en

其实相当于:

else
{
    if()
    else
}

比较该分段函数的两种写法

if(x<0)f=-1;
else if(x==0)f=0;
else f=1;
printf("%d",f);
if(x<0)printf("%d",-1);
else if(x==0)printf("%d",0);
else printf("%d",1);

更建议上面的方法,有单一出口(都是输出f),因为代码要降低重复性,出问题的时候才好统一处理。

3.2.3 if-else的常见错误

  1. 忘记写大括号的话,条件成立时只执行后面一句
  2. If后面无分号
  3. ==和=:if只要求括号里是0或非0
  4. 使人困惑的else

尊重warning!
大括号内的语句加tab缩进是代码风格。
3.2.4 多路分支

switch(print){
    case 1:
        printf("1");
        break;
    case 2:
        printf("2");
        break;
    case 3:
        printf("3");
        break;
    default:
        printf("0");
}

与if的自顶向下判断不同,switch从几个case中找出3后执行,就是说几个case的判断是同时的.
但是switch语句只能判断int整形变量,而且case后面的必须是常量(如mon=1,case 1)
Switch是先跳到对应的case处,然后一条条向下执行直到遇到break跳出switch
如果进入下一个case前还没有碰到break,那就进入下一个case
按成绩分等级的题:可以先/10,再分case。

注意一定要在每个case后加上break.

int i=1;
switch ( i%3 ) {
case 0: printf("zero");
case 1: printf("one");
case 2: printf("two");
}

结果输出的是onetwo。
解释:switch是一个路标牌,计算控制表达式的值后,就知道跳转到哪了(在哪里上车),但是分支符号只是说明switch内部位置的路标,在执行完分支后,如果后面没有break(下车提示),就会顺序执行到下面的case,直到遇到break,或者switch结束(终点站)
也就是说,程序跳到了one那个case,然后因为没有break就继续往下顺延,又输出了two。

目录
相关文章
|
1月前
|
网络协议 编译器 Linux
【C语言】结构体内存对齐:热门面试话题
【C语言】结构体内存对齐:热门面试话题
|
21天前
|
存储 搜索推荐 算法
【数据结构】树型结构详解 + 堆的实现(c语言)(附源码)
本文介绍了树和二叉树的基本概念及结构,重点讲解了堆这一重要的数据结构。堆是一种特殊的完全二叉树,常用于实现优先队列和高效的排序算法(如堆排序)。文章详细描述了堆的性质、存储方式及其实现方法,包括插入、删除和取堆顶数据等操作的具体实现。通过这些内容,读者可以全面了解堆的原理和应用。
60 16
|
5月前
|
C语言
【C语言基础篇】结构控制(中)循环结构
【C语言基础篇】结构控制(中)循环结构
|
1月前
|
编译器 C语言 Python
C语言结构
C语言结构
17 0
|
2月前
|
存储 编译器 程序员
C语言程序的基本结构
C语言程序的基本结构包括:1)预处理指令,如 `#include` 和 `#define`;2)主函数 `main()`,程序从这里开始执行;3)函数声明与定义,执行特定任务的代码块;4)变量声明与初始化,用于存储数据;5)语句和表达式,构成程序基本执行单位;6)注释,解释代码功能。示例代码展示了这些组成部分的应用。
97 10
|
2月前
|
C语言
C语言程序设计核心详解 第四章&&第五章 选择结构程序设计&&循环结构程序设计
本章节介绍了C语言中的选择结构,包括关系表达式、逻辑表达式及其运算符的优先级,并通过示例详细解释了 `if` 语句的不同形式和 `switch` 语句的使用方法。此外,还概述了循环结构,包括 `while`、`do-while` 和 `for` 循环,并解释了 `break` 和 `continue` 控制语句的功能。最后,提供了两道例题以加深理解。
|
2月前
|
存储 算法 C语言
数据结构基础详解(C语言): 二叉树的遍历_线索二叉树_树的存储结构_树与森林详解
本文从二叉树遍历入手,详细介绍了先序、中序和后序遍历方法,并探讨了如何构建二叉树及线索二叉树的概念。接着,文章讲解了树和森林的存储结构,特别是如何将树与森林转换为二叉树形式,以便利用二叉树的遍历方法。最后,讨论了树和森林的遍历算法,包括先根、后根和层次遍历。通过这些内容,读者可以全面了解二叉树及其相关概念。
|
2月前
|
C语言
C语言程序设计核心详解 第三章:顺序结构,printf(),scanf()详解
本章介绍顺序结构的基本框架及C语言的标准输入输出。程序从`main()`开始依次执行,框架包括输入、计算和输出三部分。重点讲解了`printf()`与`scanf()`函数:`printf()`用于格式化输出,支持多种占位符;`scanf()`用于格式化输入,需注意普通字符与占位符的区别。此外还介绍了`putchar()`和`getchar()`函数,分别用于输出和接收单个字符。
|
2月前
|
存储 机器学习/深度学习 C语言
数据结构基础详解(C语言): 树与二叉树的基本类型与存储结构详解
本文介绍了树和二叉树的基本概念及性质。树是由节点组成的层次结构,其中节点的度为其分支数量,树的度为树中最大节点度数。二叉树是一种特殊的树,其节点最多有两个子节点,具有多种性质,如叶子节点数与度为2的节点数之间的关系。此外,还介绍了二叉树的不同形态,包括满二叉树、完全二叉树、二叉排序树和平衡二叉树,并探讨了二叉树的顺序存储和链式存储结构。
|
3月前
|
C语言
C语言------选择结构
这篇文章是C语言选择结构的入门实训,包括多个练习题及其源代码,旨在帮助读者熟练掌握条件语句和选择结构程序设计方法,并熟悉switch语句和程序调试过程。
C语言------选择结构