解题思路:三个数排序,需要比较大小,然后排序,max和min还好,主要是中间值稍微有些难度(我第一个想到的是三目,奈何头脑有限,中间值想不明白,于是借鉴了下优质题解的回答,想清楚之后自己按照理解码的)
注意事项:注意题意,从小到大,不是从大到小(没错,我看错过)
参考代码:
#include
int main()
{
int a,b,c,max,min,mid;
scanf("%d %d %d",&a,&b,&c);
max=(a>b?a:b)>c?(a>b?a:b):c;
min=(a<b?a:b)<c?(a<b?a:b):c;
mid=a<b?(a>c?a:(c<b?c:b)):(a<c?a:(c>b?c:b));
若a<b,继续判断a和c的值,且a<c则继续判断b和c的值,谁小谁是mid
a>c则a为中间值
(a>b的情况则与其相反)
printf("%d %d %d",min,med,max);
return 0;
}
(另外,实在不理解的话,用三目还有一种方法,mid=(a+b+c)-(max+min),解决这题是够了)
0.0分
1 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复