题目:将三个数按从大到小输出
分析:本题其实也是“排序”部分的知识,但是由于只是3个数比较大小,所以我们可以不用排序的方法解决。(排序方法解决此题可以参见之前写过的一篇博客https://blog.csdn.net/melody_1016/article/details/82757950)
思路:两两比较大小,然后交换(交换时用到一个临时保存数值的变量t),a,b,c分别保存最大,中等,最小数字。
注:这里不用担心仅仅是两两比较不可能排序出,虽然是两两比较,但每一次比较完,a,b,c的值都在更新,所以最终比较完毕的序列就是所求序列。图解如下:
代码:
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
int main()
{
//将3个数按从大到小输出
int a, b, c,t;
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("a=%d,b=%d,c=%d\n", a, b, c);
system("pause");
return 0;
}
方法二:分别定义 两个变量max,min,保存a,b的最大最小值,然后用第三个数c与max,min分别进行比较;c的位置只可能是三种情况:max之前,max与min之间,min之后。
代码:
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
int main()
{
int a, b, c;
scanf("%d %d %d", &a, &b, &c);
int max, min;
if (a > b)
{
max = a;
min = b;
}
else
{
max = b;
min = a;
}
if (c > max)
{
printf("%d %d %d\n", c, max, min);
}
else if (c < min)
{
printf("%d %d %d\n", max, min, c);
}
else
{
printf("%d %d %d\n", max, c, min);
}
system("pause");
return 0;
}
结果:
注:也可以用数组的方式保存数字