【C语言程序设计】选择结构程序设计

简介: 【C语言程序设计】选择结构程序设计


前言

if语句的三种形式:

1. 第一种形式: if 语句只包含一个条件,当该条件为真(true)时,执行 if 语句块中的代码。

2. 第二种形式:if-else 语句包含两个条件,当第一个条件为真时,执行 if 语句块中的代码,否则执行 else 语句块中的代码。

3. 第三种形式:if-else-if 语句包含多个条件,当第一个条件为真时,执行第一个 if 语句块中的代码,否则检查第二个条件,第二个条件为真时执行第二个 if 语句块中的代码,否则继续检查下个条件,一直到所有条件都被检查过为止。

表达式的值在 switch 语句中只能是基本数据类型,如 int、char、枚举、bool 等。实型数据(浮点数)不能直接作为 switch 语句的表达式,因为 switch 语句在比较值时使用的是恒等比较,而实型数据的恒等比较容易出现精度问题。


一、程序阅读

#include <stdio.h>
int main() 
{
    int a, b, c, t;
    printf("输入3个整数的值: "); // 提示用户输入三个整数
    scanf("%d %d %d", &a, &b, &c); // 接收用户输入的三个整数
    if (a > b) // 如果第一个数大于第二个数,则交换它们的值
    {
        t = a;
        a = b;
        b = t;
    }
    if (a > c) // 如果第一个数大于第三个数,则交换它们的值
    {
        t = a;
        a = c;
        c = t;
    }
    if (b > c) // 如果第二个数大于第三个数,则交换它们的值
    {
        t = b;
        b = c;
        c = t;
    }
    printf("3个数按照从小到大排列为: %d %d %d\n", a, b, c); // 打印按照从小到大排列的三个数
    return 0;
}

运行结果:

输入:18 66 32

二、程序改错

程序中有错误,上机调试程序,修改有错误的语句行,并输出正确的运行结果。

修正后的代码:

#include <stdio.h>
int main() 
{
    int x;
    printf("请输入一个整数: ");
    scanf("%d", &x);
    if (x % 3 == 0 && x % 5 == 0)
        printf("yes !\n");
    else
        printf("no !\n");
    return 0;
}

修改后的程序中,修复了以下错误:

1.在使用scanf函数接收用户输入时,修正了缺少&符号的问题。

2.在if语句中,修正了比较运算符应该使用==而不是=的问题。

运行结果:

输入:15

三、程序设计

编写一个程序实现这样的功能:商店卖软盘,每片定价3.5元,按购买的数量可给予如下的优惠:购买满100片,优惠5%;购买满200片,优惠6%;购买满300片,优惠8%;购买满400片,优惠10%;购买500片以上,优惠15%。根据不同的购买量,打印应付货款。(用switch语句编程

实现代码:

#include <stdio.h> 
int main ()
{
    int x;
    float y, total;
    printf("请输入软盘购买数量:");
    scanf ("%d", &x);
    if (x < 0)
    {
        printf("你输入的值超出正常范围!");
    }
    else
    {
        switch (x / 100) 
        {
            case 0:
                y = 0;
                break;
            case 1:
                y = 0.05;
                break;
            case 2:
                y = 0.06;
                break;
            case 3:
                y = 0.08;
                break;
            case 4:
                y = 0.10;
                break;
            default:
                y = 0.15;
        }
        total = 3.5 * x * (1 - y);
        printf("应付价钱=%0.2f\n", total);
    }
    return 0;
}

运行结果:

输入:500

代码思路:

1. 首先,定义了三个变量:x是购买软盘的数量,y是折扣率(浮点数),total是最终的应付价钱(浮点数)。

2. 代码通过printf函数打印出提示信息,要求用户输入购买数量。

3. 然后使用scanf函数将用户输入的值存储到变量x中。

4. 接下来,代码通过if-else语句进行条件判断。如果x小于0,表示输入的值超出了正常范围,那么代码会打印一条错误信息。如果x大于等于0,则进入else语句块。

5. 在else语句块中,通过switch语句根据x除以100的商的值来确定折扣率y的取值。根据不同的商值,将y设置为不同的折扣率。如果商值为0,表示购买数量小于100个,那么折扣率y为0;如果商值为1,表示购买数量在100到199之间,那么折扣率y为0.05,以此类推。如果商值超过4,则表示购买数量大于等于500个,折扣率y为0.15。

6. 计算最终的应付价钱,将结果存储到变量total中。计算公式为:total = 3.5 * x * (1 - y),其中3.5是每个软盘的价格。

7. 最后,使用printf函数打印出应付价钱的结果,保留两位小数。

8. 程序执行完毕,返回0表示正常结束。


总结

当涉及到对不同情况进行处理和判断时,C语言中常用的语言结构是选择结构。选择结构的关键就在于判断条件。根据判断的条件是否成立,程序会执行其中一个分支里面的代码。

C语言中有两种常用的选择结构:if-else和switch-case。if-else语句用于针对一个条件判断,当条件为真时执行一个代码块,否则执行另一个代码块。switch-case语句用于根据一个表达式的值,在同的情况下执行不同的代码块。

目录
相关文章
|
1月前
|
网络协议 编译器 Linux
【C语言】结构体内存对齐:热门面试话题
【C语言】结构体内存对齐:热门面试话题
|
13天前
|
存储 搜索推荐 算法
【数据结构】树型结构详解 + 堆的实现(c语言)(附源码)
本文介绍了树和二叉树的基本概念及结构,重点讲解了堆这一重要的数据结构。堆是一种特殊的完全二叉树,常用于实现优先队列和高效的排序算法(如堆排序)。文章详细描述了堆的性质、存储方式及其实现方法,包括插入、删除和取堆顶数据等操作的具体实现。通过这些内容,读者可以全面了解堆的原理和应用。
56 16
|
1月前
|
编译器 C语言 Python
C语言结构
C语言结构
15 0
|
2月前
|
存储 算法 C语言
数据结构基础详解(C语言): 二叉树的遍历_线索二叉树_树的存储结构_树与森林详解
本文从二叉树遍历入手,详细介绍了先序、中序和后序遍历方法,并探讨了如何构建二叉树及线索二叉树的概念。接着,文章讲解了树和森林的存储结构,特别是如何将树与森林转换为二叉树形式,以便利用二叉树的遍历方法。最后,讨论了树和森林的遍历算法,包括先根、后根和层次遍历。通过这些内容,读者可以全面了解二叉树及其相关概念。
|
2月前
|
存储 C语言
C语言程序设计核心详解 第十章:位运算和c语言文件操作详解_文件操作函数
本文详细介绍了C语言中的位运算和文件操作。位运算包括按位与、或、异或、取反、左移和右移等六种运算符及其复合赋值运算符,每种运算符的功能和应用场景都有具体说明。文件操作部分则涵盖了文件的概念、分类、文件类型指针、文件的打开与关闭、读写操作及当前读写位置的调整等内容,提供了丰富的示例帮助理解。通过对本文的学习,读者可以全面掌握C语言中的位运算和文件处理技术。
|
2月前
|
存储 C语言
C语言程序设计核心详解 第七章 函数和预编译命令
本章介绍C语言中的函数定义与使用,以及预编译命令。主要内容包括函数的定义格式、调用方式和示例分析。C程序结构分为`main()`单框架或多子函数框架。函数不能嵌套定义但可互相调用。变量具有类型、作用范围和存储类别三种属性,其中作用范围分为局部和全局。预编译命令包括文件包含和宏定义,宏定义分为无参和带参两种形式。此外,还介绍了变量的存储类别及其特点。通过实例详细解析了函数调用过程及宏定义的应用。
|
2月前
|
存储 人工智能 C语言
C语言程序设计核心详解 第八章 指针超详细讲解_指针变量_二维数组指针_指向字符串指针
本文详细讲解了C语言中的指针,包括指针变量的定义与引用、指向数组及字符串的指针变量等。首先介绍了指针变量的基本概念和定义格式,随后通过多个示例展示了如何使用指针变量来操作普通变量、数组和字符串。文章还深入探讨了指向函数的指针变量以及指针数组的概念,并解释了空指针的意义和使用场景。通过丰富的代码示例和图形化展示,帮助读者更好地理解和掌握C语言中的指针知识。
|
2月前
|
存储 机器学习/深度学习 C语言
数据结构基础详解(C语言): 树与二叉树的基本类型与存储结构详解
本文介绍了树和二叉树的基本概念及性质。树是由节点组成的层次结构,其中节点的度为其分支数量,树的度为树中最大节点度数。二叉树是一种特殊的树,其节点最多有两个子节点,具有多种性质,如叶子节点数与度为2的节点数之间的关系。此外,还介绍了二叉树的不同形态,包括满二叉树、完全二叉树、二叉排序树和平衡二叉树,并探讨了二叉树的顺序存储和链式存储结构。
|
2月前
|
存储 C语言
C语言程序设计核心详解 第九章 结构体与链表概要详解
本文档详细介绍了C语言中的结构体与链表。首先,讲解了结构体的定义、初始化及使用方法,并演示了如何通过不同方式定义结构体变量。接着,介绍了指向结构体的指针及其应用,包括结构体变量和结构体数组的指针操作。随后,概述了链表的概念与定义,解释了链表的基本操作如动态分配、插入和删除。最后,简述了共用体类型及其变量定义与引用方法。通过本文档,读者可以全面了解结构体与链表的基础知识及实际应用技巧。
|
1月前
|
C语言 C++
C语言 之 内存函数
C语言 之 内存函数
33 3