【C语言程序设计——选择结构程序设计】按从小到大排序三个数(头歌实践教学平台习题)【合集】

简介: 本任务要求从键盘输入三个数,并按从小到大的顺序排序后输出。主要内容包括任务描述、编程要求、相关知识(选择结构、主要语句类型、比较操作、交换操作)、测试说明及通关代码。通过掌握条件语句和交换逻辑,实现对三个数的排序并输出结果。测试用例验证了代码的正确性,确保程序能够处理不同输入情况。任务核心是使用选择结构(如 if-else 语句)进行条件判断,并通过交换操作完成排序。例如,若 a > b,则交换 a 和 b 的值。最终输出排序后的三个数。测试示例展示了不同的输入及其预期输出,确保程序功能的正确性。祝你顺利完成任务!

 

目录😋

任务描述

编程要求

相关知识

1. 选择结构

2. 主要语句类型

3. 比较操作

4. 交换操作

测试说明

通关代码

测试结果


任务描述

本关任务:从键盘上输入三个数,请按从小到大的顺序排序并打印输出排序后的结果。

编程要求

根据提示,在右侧编辑器 Begin-End 之间补充代码,计算并输出对应二次方程的根。

相关知识

为了完成本关任务,你需要掌握:

  1. 选择结构基本概念
  2. 选择结构主要语句类型
  3. 比较操作
  4. 交换操作

1. 选择结构

选择结构是程序设计中的一种基本结构,用于根据给定条件决定程序执行的不同分支路径。其核心在于对条件表达式进行求值判断,当条件满足特定要求时,程序执行相应的一组语句;若条件不满足,则可能执行其他分支语句或跳过当前代码块继续执行后续程序。

条件表达式通常由关系运算符(如大于、小于、等于等)、逻辑运算符(如与、或、非)以及其他能产生布尔值的表达式构成。例如,在判断一个数是否大于 10 的场景中,条件表达式为 “num> 10”,这里的 “num” 是程序中的变量,通过比较其值与 10 的大小关系来确定条件的真假。

常见的选择结构形式包括 if 语句、if - else 语句和 switch 语句。if 语句是最基础的形式,当条件为真时执行其内部的语句块;if - else 语句在 if 条件不成立时提供了另一个可执行的语句块,确保在两种不同条件结果下程序都有明确的执行路径;switch 语句则适用于针对一个表达式的多个固定值进行判断,根据表达式的值与各个 case 后的常量值匹配情况,执行相应 case 分支下的语句,直到遇到 break 语句跳出 switch 结构,若没有匹配值则执行 default 分支(可选)。选择结构使得程序能够模拟现实生活中的决策过程,对不同情况做出不同反应,从而实现复杂的逻辑和功能,增强程序的灵活性和适应性,广泛应用于各类编程场景,如数据处理、算法实现、用户交互逻辑处理等,是构建有效程序逻辑的关键组成部分。

2. 主要语句类型

条件语句(if、if-else、switch)

  • if 语句if语句是 C 语言中用于实现条件判断和分支执行的基本结构之一。其核心在于根据给定的条件表达式的真假来决定是否执行特定的代码块。
  • 条件表达式可以是任何能够得出布尔值(真或假)的表达式,例如比较运算(><>=<===!=)、逻辑运算(&&||!)以及函数调用(只要函数返回值能被隐式转换为布尔值)等的组合。例如:if (a > 10 && b < 20) { /* 执行语句 */ },这里只有当a大于10并且b小于20这两个条件同时满足时,花括号内的代码才会被执行。
  • 执行语句块可以是一条或多条语句,如果只有一条语句,花括号可以省略,但为了增强代码的可读性和可维护性,通常建议加上花括号。例如:if (x == 5) printf("x is 5\n"); 这种写法在简单情况下可行,但如果后续需要添加更多语句,就容易出现错误,而写成 if (x == 5) { printf("x is 5\n"); otherFunctionCall(); } 则更加清晰和安全。
  • if - else 语句if - else语句在if语句的基础上,为条件不成立的情况提供了另一个执行路径。当if后面的条件表达式为假时,就会执行else后面的语句块。
  • 这种结构在很多实际场景中非常有用,比如前面提到的判断成绩是否及格的例子,它确保了程序在任何情况下都有明确的输出,避免了因条件不满足而导致的不确定性。再比如在一个判断数字正负性的程序中:if (num > 0) { printf("正数\n"); } else if (num < 0) { printf("负数\n"); } else { printf("零\n"); },这里通过else if进一步细分了条件,对num的三种可能情况(大于0、小于0、等于0)都进行了相应的处理,使程序的逻辑更加严谨和完整。
  • 用于根据不同条件执行不同的代码块。

例如,判断一个数是奇数还是偶数:

int num;
scanf("%d", &num);
if (num % 2 == 0) {
    // 当num除以2的余数为0时,说明num是偶数
    printf("%d is even\n", num);
} else {
    // 当num除以2的余数不为0时,说明num是奇数
    printf("%d is odd\n", num);
}
image.gif
  1. 通过scanf函数从用户输入获取一个整数,并存储在num变量中。
  2. 使用if语句判断num是否为偶数。num % 2 == 0这个条件表达式利用了取模运算(%),当num除以2的余数为0时,条件为真,就会执行if语句块内的printf("%d is even\n", num);,输出num是偶数的信息。
  3. 如果num除以2的余数不为0,即条件为假,那么就会执行else语句块内的printf("%d is odd\n", num);,输出num是奇数的信息。
  • switch语句
  • switch语句主要用于处理多个固定的、离散的选项情况。它根据一个整型表达式(通常是一个变量)的值,与各个case常量进行匹配,一旦匹配成功,就执行对应的case分支下的语句,直到遇到break语句或者switch语句结束。
  • 当有多个固定的选项时,可以使用switch语句。

例如,在一个简单的菜单选择程序中:

int choice;
scanf("%d", &choice);
switch (choice) {
    case 1:
        printf("打开文件\n");
        break;
    case 2:
        printf("保存文件\n");
        break;
    case 3:
        printf("退出程序\n");
        break;
    default:
        printf("无效的选择,请重新输入\n");
}
image.gif

这里,switch表达式choice的值会依次与case 1case 2case 3进行比较,如果choice等于1,就会执行printf("打开文件\n");,然后遇到break语句,跳出switch结构;如果choice的值与所有case常量都不匹配,就会执行default分支下的语句,提示用户输入无效。

需要注意的是,case常量的值必须是唯一的,且在同一个switch语句中不能重复;break语句的作用至关重要,如果遗漏break,程序将会继续执行下一个case分支的语句,这可能不是预期的行为,这种现象被称为 “case 穿透”,在某些特定情况下可以利用这一特性来简化代码,但在大多数情况下,需要谨慎使用break来确保程序的正确性。

3. 比较操作

       比较操作通过if语句及大于号(>)比较运算符实现,例如if(a > b)判断ab大小,if(a > c)判断ac大小,if(b > c)判断bc大小,依结果决定是否执行后续代码。

4. 交换操作

       交换操作借助临时变量t,以if(a > b)为例,条件成立时,先t = a备份a值,再a = bb值赋给a,最后b = t完成ab交换,其他两次交换同理,通过比较与交换配合实现三个数从小到大排序并输出。

测试说明

平台会对你编写的代码进行测试:

测试输入:

6 10 2

预期输出:

从小到大排序为:2,6,10

测试输入:

12 -5 8

预期输出:

从小到大排序为:-5,8,12

开始你的任务吧,祝你成功!


通关代码

#include "stdio.h"
int main()
{
    int a,b,c,t;
    //printf("请输入三个数:");
   /*********Begin*********/
     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("从小到大排序为:%d,%d,%d",a,b,c);
    return 0;
      
   /*********End**********/ 
}

image.gif


测试结果

image.gif

image.gif

目录
相关文章
|
15天前
|
C语言
【C语言程序设计——函数】亲密数判定(头歌实践教学平台习题)【合集】
本文介绍了通过编程实现打印3000以内的全部亲密数的任务。主要内容包括: 1. **任务描述**:实现函数打印3000以内的全部亲密数。 2. **相关知识**: - 循环控制和跳转语句(for、while循环,break、continue语句)的使用。 - 亲密数的概念及历史背景。 - 判断亲密数的方法:计算数A的因子和存于B,再计算B的因子和存于sum,最后比较sum与A是否相等。 3. **编程要求**:根据提示在指定区域内补充代码。 4. **测试说明**:平台对代码进行测试,预期输出如220和284是一组亲密数。 5. **通关代码**:提供了完整的C语言代码实现
54 24
|
11天前
|
存储 C语言
【C语言程序设计——函数】递归求斐波那契数列的前n项(头歌实践教学平台习题)【合集】
本关任务是编写递归函数求斐波那契数列的前n项。主要内容包括: 1. **递归的概念**:递归是一种函数直接或间接调用自身的编程技巧,通过“俄罗斯套娃”的方式解决问题。 2. **边界条件的确定**:边界条件是递归停止的条件,确保递归不会无限进行。例如,计算阶乘时,当n为0或1时返回1。 3. **循环控制与跳转语句**:介绍`for`、`while`循环及`break`、`continue`语句的使用方法。 编程要求是在右侧编辑器Begin--End之间补充代码,测试输入分别为3和5,预期输出为斐波那契数列的前几项。通关代码已给出,需确保正确实现递归逻辑并处理好边界条件,以避免栈溢出或结果
48 16
|
15天前
|
Serverless C语言
【C语言程序设计——循环程序设计】利用循环求数值 x 的平方根(头歌实践教学平台习题)【合集】
根据提示在右侧编辑器Begin--End之间的区域内补充必要的代码,求解出数值x的平方根;运用迭代公式,编写一个循环程序,求解出数值x的平方根。注意:不能直接用平方根公式/函数求解本题!开始你的任务吧,祝你成功!​ 相关知识 求平方根的迭代公式 绝对值函数fabs() 循环语句 一、求平方根的迭代公式 1.原理 在C语言中,求一个数的平方根可以使用牛顿迭代法。对于方程(为要求平方根的数),设是的第n次近似值,牛顿迭代公式为。 其基本思想是从一个初始近似值开始,通过不断迭代这个公式,使得越来越接近。
46 18
|
15天前
|
C语言
【C语言程序设计——循环程序设计】枚举法换硬币(头歌实践教学平台习题)【合集】
本文档介绍了编程任务的详细内容,旨在运用枚举法求解硬币等额 - 循环控制语句(`for`、`while`)及跳转语句(`break`、`continue`)的使用。 - 循环嵌套语句的基本概念和应用,如双重`for`循环、`while`嵌套等。 3. **编程要求**:根据提示在指定区域内补充代码。 4. **测试说明**:平台将对编写的代码进行测试,并给出预期输出结果。 5. **通关代码**:提供完整的代码示例,帮助理解并完成任务。 6. **测试结果**:展示代码运行后的实际输出,验证正确性。 文档结构清晰,逐步引导读者掌握循环结构与嵌套的应用,最终实现硬币兑换的程序设计。
46 19
|
15天前
|
算法 C语言
【C语言程序设计——循环程序设计】求解最大公约数(头歌实践教学平台习题)【合集】
采用欧几里得算法(EuclideanAlgorithm)求解两个正整数的最大公约数。的最大公约数,然后检查最大公约数是否大于1。如果是,就返回1,表示。根据提示,在右侧编辑器Begin--End之间的区域内补充必要的代码。作为新的参数传递进去。这个递归过程会不断进行,直到。有除1以外的公约数;变为0,此时就找到了最大公约数。开始你的任务吧,祝你成功!是否为0,如果是,那么。就是最大公约数,直接返回。
69 18
|
15天前
|
C语言
【C语言程序设计——循环程序设计】统计海军鸣放礼炮声数量(头歌实践教学平台习题)【合集】
有A、B、C三艘军舰同时开始鸣放礼炮各21响。已知A舰每隔5秒1次,B舰每隔6秒放1次,C舰每隔7秒放1次。编程计算观众总共听到几次礼炮声。根据提示,在右侧编辑器Begin--End之间的区域内补充必要的代码。开始你的任务吧,祝你成功!
46 13
|
15天前
|
存储 算法 安全
【C语言程序设计——选择结构程序设计】按从小到大排序三个数(头歌实践教学平台习题)【合集】
本任务要求从键盘输入三个数,并按从小到大的顺序排序后输出。主要内容包括: - **任务描述**:实现三个数的排序并输出。 - **编程要求**:根据提示在编辑器中补充代码。 - **相关知识**: - 选择结构(if、if-else、switch) - 主要语句类型(条件语句) - 比较操作与交换操作 - **测试说明**:提供两组测试数据及预期输出。 - **通关代码**:完整代码示例。 - **测试结果**:展示测试通过的结果。 通过本任务,你将掌握基本的选择结构和排序算法的应用。祝你成功!
30 4
|
15天前
|
搜索推荐 算法 数据处理
【C++数据结构——内排序】希尔排序(头歌实践教学平台习题)【合集】
本文介绍了希尔排序算法的实现及相关知识。主要内容包括: - **任务描述**:实现希尔排序算法。 - **相关知识**: - 排序算法基础概念,如稳定性。 - 插入排序的基本思想和步骤。 - 间隔序列(增量序列)的概念及其在希尔排序中的应用。 - 算法的时间复杂度和空间复杂度分析。 - 代码实现技巧,如循环嵌套和索引计算。 - **测试说明**:提供了测试输入和输出示例,帮助验证代码正确性。 - **我的通关代码**:给出了完整的C++代码实现。 - **测试结果**:展示了代码运行的测试结果。 通过这些内容,读者可以全面了解希尔排序的原理和实现方法。
46 10
|
15天前
|
存储 人工智能 算法
【C++数据结构——内排序】二路归并排序(头歌实践教学平台习题)【合集】
本关任务是实现二路归并算法,即将两个有序数组合并为一个有序数组。主要内容包括: - **任务描述**:实现二路归并算法。 - **相关知识**: - 二路归并算法的基本概念。 - 算法步骤:通过比较两个有序数组的元素,依次将较小的元素放入新数组中。 - 代码示例(以 C++ 为例)。 - 时间复杂度为 O(m+n),空间复杂度为 O(m+n)。 - **测试说明**:平台会对你编写的代码进行测试,提供输入和输出示例。 - **通关代码**:提供了完整的 C++ 实现代码。 - **测试结果**:展示代码运行后的排序结果。 开始你的任务吧,祝你成功!
32 10
|
15天前
|
存储 C语言
【C语言程序设计——循环程序设计】利用数列的累加和求 sinx(头歌实践教学平台习题)【合集】
项的累加和,一般会使用循环结构,在每次循环中计算出当前项的值(可能基于通项公式或者递推关系),然后累加到一个用于存储累加和的变量中。在C语言中推导数列中的某一项,通常需要依据数列给定的通项公式或者前后项之间的递推关系来实现。例如,对于一个简单的等差数列,其通项公式为。的级数,其每一项之间存在特定的递推关系(后项的分子是其前项的分子乘上。,计算sinx的值,直到最后一项的绝对值小于。为项数),就可以通过代码来计算出指定项的值。对于更复杂的数列,像题目中涉及的用于近似计算。开始你的任务吧,祝你成功!
33 6