【C语言基础篇】结构控制(上)顺序结构和选择结构

简介: 【C语言基础篇】结构控制(上)顺序结构和选择结构

C语⾔是结构化的程序设计语⾔,这⾥的结构指的是顺序结构、选择结构、循环结构。也就是说在C语言所有的代码都是这三种结构。

本篇文章将会着重讲解选择结构

关于C语言循环结构详细讲解请参阅这篇文章

【C语言基础篇】结构控制(中)循环结构-CSDN博客

关于转向语句break、continue 、goto和return语句请参阅这篇文章

【C语言基础篇】结构控制(下)转向语句break、continue、goto、return-CSDN博客

一、顺序结构

顺序结构的程序设计是最简单的,只要按照解决问题的顺序写出相应的语句就行,它的执行顺序是自上而下,依次执行。如下图所示,这里不再赘述。

#include <stdio.h>
 
int main()
{
  int a = 0;
  printf("a = %d\n",a);
  a = 1;
  printf("a = %d\n",a);
 
  return 0;
}

二、选择结构

选择结构用于判断给定的条件,根据判断的结果判断某些条件,根据判断的结果来控制程序的流程。

选择结构的语句称为选择语句分支语句

C语言中的选择结构通过 if 语句和 switch 语句来实现。

1.  if语句

if语句的语法形式

一、单分支控制选择语句——单独的if 跟单条语句

if(表达式)

       语句;

if语句的实现逻辑

表达式成立(为真),则语句执行;表达式不成立(为假),则语句不执行。

在C语⾔中,0为假,非0表示真,也就是表达式的结果如果是0,则语句不执行,表达式的结果如果是 不是0,则语句执行

注意:if后面不带大括号时,只能跟一条语句,多出的语句不再被if控制

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

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

二、单分支控制选择语句——if后面跟多条语句时,需要用大括号括起来才有效

if(表达式)

{

       语句1;

       语句2;

       ……

}

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

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

三、双分支控制选择语句——用于非此即彼的关系时

if(表达式)

{

       ……

}

else

{

        ……

}

例⼦:输⼊⼀个整数,并进行判断,如果是奇数,输出奇数;否则输出偶数

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

四、多分支的控制的选择语句——用于复杂的选择结构中

if(表达式)
{
        ……
}
else if(表达式)
{
         ……
}
else
{
         ……
}

⽐如: 输⼊⼀个整数,如果是正数,输出正数;如果不是正数则输出:负数;否则,输出0.

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

2.  switch语句

switch 语句是⼀种特殊形式的if...else... 结构,用于判断条件有多个结果的情况。它把多重 的 else if 改成更易用、可读性更好的形式。

语法形式

switch(整型表达式)
{
case 常量1:语句1;
case 常量2:语句2;
case 常量n:语句n;
default: 语句n+1;
}

注意

  • (表达式)只能是char型或者int型;
  • case 后面至少要有一个空格,常量后面是冒号
  • 每⼀个 case 语句中的代码执行完成后,需要加上 break ,才能跳出这个switch语句
  • 在 switch 语句中 case 语句和 default 语句是没有顺序要求的,只要你的顺序是满⾜实 际需求的就可以。 不过我们通常是把 default ⼦句放在最后处理的

例如:输⼊任意⼀个整数值,计算除3之后的余数

#include <stdio.h>
 
int main()
{
     int n = 0;
     scanf("%d", &n);
     switch(n%3)
     {
     case 0:
         printf("整除,余数为0\n"); 
         break;
     case 1:
         printf("余数是1\n"); 
         break;
     case 2:
         printf("余数是2\n"); 
         break;
 }
 return 0;
}

当然,上面的代码也可以使用 if else语句来实现

#include <stdio.h>
int main()
{
    int n = 0;
    scanf("%d", &n);
    if (n % 3 == 0)
    {
        printf("整除,余数为0\n");
    }
    else if (n % 3 == 1)
    {
        printf("余数是1\n");
    }
    else
    {
        printf("余数是2\n");
    }
    return 0;
}

3. 总结

在实际使用中,应当根据实际情况来灵活使用两种选择结构的控制方式,一般情况下,if else语句是常用的语句,但在分支较多的情况下,使用switch语句会更加清晰和方便。

 


相关文章
|
1月前
|
网络协议 编译器 Linux
【C语言】结构体内存对齐:热门面试话题
【C语言】结构体内存对齐:热门面试话题
|
16天前
|
存储 搜索推荐 算法
【数据结构】树型结构详解 + 堆的实现(c语言)(附源码)
本文介绍了树和二叉树的基本概念及结构,重点讲解了堆这一重要的数据结构。堆是一种特殊的完全二叉树,常用于实现优先队列和高效的排序算法(如堆排序)。文章详细描述了堆的性质、存储方式及其实现方法,包括插入、删除和取堆顶数据等操作的具体实现。通过这些内容,读者可以全面了解堆的原理和应用。
59 16
|
5月前
|
C语言
【C语言基础篇】结构控制(中)循环结构
【C语言基础篇】结构控制(中)循环结构
|
1月前
|
编译器 C语言 Python
C语言结构
C语言结构
16 0
|
2月前
|
存储 编译器 程序员
C语言程序的基本结构
C语言程序的基本结构包括:1)预处理指令,如 `#include` 和 `#define`;2)主函数 `main()`,程序从这里开始执行;3)函数声明与定义,执行特定任务的代码块;4)变量声明与初始化,用于存储数据;5)语句和表达式,构成程序基本执行单位;6)注释,解释代码功能。示例代码展示了这些组成部分的应用。
95 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语言------选择结构