四个人排序——c++选择结构提高

这一章,我们要结束选择结构。判断四个数的大小并输出。

我先来教大家一个判断两数大小的"捷径":

cpp 复制代码
max(a,b);

这是两个数的大小,四个数的大小判断只能用if嵌套:

cpp 复制代码
if(......)
{
    if(......)
    {
        ......
    }
}

if嵌套,是在第一个if成立后执行下一个if。

那么四个数比比大小可以死套if,但可以超前用sort,这里不讲,现在最好用变量套 。然后练道题:

题目描述

上课之前,老师让小明、小军、小强和小刚按身高从小到大排成一队,希望你能帮忙写一个程序:从键盘输入小明、小军、小强和小刚的身高,按从小到大的顺序排成一队。

比如:从键盘上输入145、149、155和140,那么就在屏幕上输出"140<145<149<155"。

输入格式

输入文件第一行是四个整数,分别表示四人的身高。

输出格式

输出的结果表示从小到大排序。

样例

输入#1

120 125 108 135

输出#1

108<120<125<135

按照题目要求,变量为int即可,那么代码如下:

cpp 复制代码
//written by wanghaidong 2022.11.9
#include<bits/stdc++.h>
using namespace std;
int main()
{
    int a,b,c,d,t;
    cin>>a>>b>>c>>d;
    //以下三个if跑完之后,就能保证a是最小的
    if(a>=b)
    {
        t=a;
        a=b;
        b=t;
    }
    if(a>=c)
    {
        t=a;
        a=c;
        c=t;
    }
    if(a>=d)
    {
        t=a;
        a=d;
        d=t;
    }
    //以下两个if跑完之后,就能保证b是第二小的
    if(b>=c)
    {
        t=b;
        b=c;
        c=t;
    }
    if(b>=d)
    {
        t=b;
        b=d;
        d=t;
    }
    //此if跑完之后就能保证c是第三小的,同时d就一定是最大的
    if(c>=d)
    {
        t=c;
        c=d;
        d=t;
    }
    cout<<a<<"<"<<b<<"<"<<c<<"<"<<d;
    return 0;
}
相关推荐
计算机小白一个4 小时前
蓝桥杯 Java B 组之设计 LRU 缓存
java·算法·蓝桥杯
万事可爱^5 小时前
HDBSCAN:密度自适应的层次聚类算法解析与实践
算法·机器学习·数据挖掘·聚类·hdbscan
黑不溜秋的5 小时前
C++ 设计模式 - 策略模式
c++·设计模式·策略模式
大数据追光猿7 小时前
Python应用算法之贪心算法理解和实践
大数据·开发语言·人工智能·python·深度学习·算法·贪心算法
Dream it possible!7 小时前
LeetCode 热题 100_在排序数组中查找元素的第一个和最后一个位置(65_34_中等_C++)(二分查找)(一次二分查找+挨个搜索;两次二分查找)
c++·算法·leetcode
夏末秋也凉7 小时前
力扣-回溯-46 全排列
数据结构·算法·leetcode
南宫生7 小时前
力扣每日一题【算法学习day.132】
java·学习·算法·leetcode
柠石榴7 小时前
【练习】【回溯No.1】力扣 77. 组合
c++·算法·leetcode·回溯
Leuanghing7 小时前
【Leetcode】11. 盛最多水的容器
python·算法·leetcode
qy发大财7 小时前
加油站(力扣134)
算法·leetcode·职场和发展