牛客网NC22015:最大值和最小值

牛客网NC22015:最大值和最小值

题目描述

题目要求

输入 :一行,包含三个整数 a, b, c (1≤a,b,c≤1000000)
输出:两行,第一行输出最大数,第二行输出最小数。

样例输入

复制代码
1 2 3

样例输出

复制代码
The maximum number is : 3
The minimum number is : 1

解题思路

这道题目要求我们找出三个数中的最大值和最小值。解题思路非常直接:

  1. 初始化最大值和最小值为第一个数 a
  2. 将第二个数 b 与当前最大值比较,如果 b 更大,则更新最大值;否则,与当前最小值比较,如果 b 更小,则更新最小值
  3. 将第三个数 c 与当前最大值比较,如果 c 更大,则更新最大值
  4. 将第三个数 c 与当前最小值比较,如果 c 更小,则更新最小值
  5. 按照要求格式输出最大值和最小值

这种方法的时间复杂度是 O(1),空间复杂度也是 O(1),对于只有三个数的情况非常高效。

代码实现

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

int main(){
    int a, b, c, max, min;
    
    // 读取三个整数
    cin >> a >> b >> c;
    
    // 初始化最大值和最小值为第一个数
    max = a;
    min = a;
    
    // 处理第二个数
    if(b >= max)
        max = b;
    else
        min = b;
    
    // 处理第三个数(最大值)
    if(c >= max)
        max = c;
    
    // 处理第三个数(最小值)。注意这两个判断是独立的,因为 c 可能既不是最大值也不是最小值
    if(c < min)
        min = c;
        
    // 按要求格式输出结果
    printf("The maximum number is : %d\n", max);
    printf("The minimum number is : %d", min);
    
    return 0;
}

代码分析

  1. 头文件引入#include<bits/stdc++.h> 包含了 C++ 标准库中常用的所有头文件,在竞赛中常用于简化代码。

  2. 变量定义:定义了五个整型变量 a, b, c 用于存储输入的三个数,max 和 min 分别用于记录最大值和最小值。

  3. 初始化:将 max 和 min 都初始化为第一个数 a,这是一个常见的初始化技巧。

  4. 处理第二个数

    • 如果 b 大于等于当前最大值,则更新最大值为 b
    • 否则,说明 b 小于 a,更新最小值为 b(因为此时 min=a,而 b<a)
  5. 处理第三个数

    • 先判断 c 是否大于等于当前最大值,如果是则更新最大值
    • 再判断 c 是否小于当前最小值,如果是则更新最小值
    • 注意这两个判断是独立的,因为 c 可能既不是最大值也不是最小值
  6. 输出结果:使用 printf 函数按照题目要求的格式输出最大值和最小值。

算法优化点

这个算法已经非常简洁高效,对于只有三个数的情况,无法再进一步优化时间和空间复杂度。不过,如果处理的是任意数量的数据,我们可以使用更通用的方法,如:

  • 使用库函数 std::max()std::min()
  • 对于多个数的情况,可以使用循环或算法库中的 std::max_element()std::min_element()

总结

这道题目虽然简单,但它展示了解决最值问题的基本思路。在实际编程中,找最值是一个非常常见的操作,掌握这种基础算法对于解决更复杂的问题非常有帮助。

另外,本题也体现了程序设计中的一个重要思想:通过合理的初始化和条件判断,可以减少冗余操作,提高代码效率。

相关推荐
国科安芯2 分钟前
ASM232S电气特性与TIA/EIA-232-F及ITU V.28标准符合性深度分析
单片机·嵌入式硬件·算法·安全·架构
资深流水灯工程师2 分钟前
MEMS 加速度计在手表、手环及无人机上的核心应用
算法
阿文的代码库7 分钟前
递归与迭代的形式实现
算法·动态规划
不吃土豆的马铃薯8 分钟前
高性能服务器程序框架详解(包括Reactor,有限状态机等)
linux·服务器·开发语言·网络·c++
春日见8 分钟前
自动驾驶数据驱动规控进化之路
运维·服务器·人工智能·深度学习·算法·机器学习·自动驾驶
普贤莲花16 分钟前
【【2026年第22周---写于20260531】---好好工作,好好生活】
程序人生·算法·leetcode·生活
Bingorl17 分钟前
机器学习之聚类算法
算法·机器学习·聚类
CS创新实验室17 分钟前
数据结构:程序世界的“收纳术“
数据结构
郝学胜-神的一滴19 分钟前
Qt 高级开发 020:水平布局手写代码实战
开发语言·c++·qt·系统架构·软件构建·用户界面
小欣加油21 分钟前
leetcode2126 摧毁小行星
数据结构·c++·算法·leetcode·职场和发展