方法1:两两比较,6种可能性,用if嵌套判断(不重新赋予abc新值,直接用他们本身判断,相等的情况无法输出,可优化,但该方法比较繁琐)
#include <stdio.h>
int main()
{
int a, b, c = 0;
printf("输入任意三个整数\n");
scanf("%d %d %d", &a, &b, &c);
if (b > a)
{
if (c > b)
{
printf("从大到小排序\n%d>%d>%d", c, b, a);
}
else if (c < b)
{
if (a > c)
printf("从大到小排序\n%d>%d>%d", b, a, c);
else if (c > a)
{
printf("从大到小排序\n%d>%d>%d", b, c, a);
}
}
}
else if (a > b)
{
if (c > a)
{
printf("从大到小排序\n%d>%d>%d", c, a, b);
}
else if (a > c)
{
if (b > c)
printf("从大到小排序\n%d>%d>%d", a, b, c);
else if (c > b)
{
printf("从大到小排序\n%d>%d>%d", a, c, b);
}
}
}
return 0;
}
方法2:三个数两两比较,每次都把最大的数放到前面,最多3个if都执行一下排序完成,其他时候有些if不用执行
#include <stdio.h>
int main()
{
int a, b, c, x;
printf("输入任意三个整数\n");
scanf("%d %d %d", &a, &b, &c);
// 默认排序a>b>c讨论不是他们的情况↓
if (b > a) // 当b大于a时
{
x = a;
a = b;
b = x; // 把b和a里的数值,换了个位置
}//执行完毕后,排序依旧是abc,但是a里的值一定大于b里的,这样还不确定c什么情况
if (c > b) // 然后判断后面两个数b和c谁大,默认排序是bc,讨论不是的情况
{
x = b;
b = c;
c = x;
}//执行完毕后第二个数一定大于第三个数
if (c > a) // 最后判断前两个数排序,默认a在前,讨论不是的情况
{
x = a;
a = c;
c = x;
}// 两个大数就知道谁更大了
printf("%d %d %d\n", a, b, c);//这样abc里面的值就是按照从大到小排列了
return 0;
}
交换两个数的值的时候需要拿一个空杯子x来暂时盛一下其中一个数,不然就丢失了
3257

被折叠的 条评论
为什么被折叠?



