解题思路:思路一:用if 语句,先比较出两个数的大小,再将两者中大的那个数与第三个比较;思路二:用if语句,先确定一个数为最大数,再将剩余两个数与它比较,大的为max;思路三:用二维数组,采用冒泡排序的方法。将数组中的数两两比较,如果a[i]<a[i+1],交换位置。但这种方法所耗时间较长,无法通过,更适用于三个数以上的比较,这里只是介绍一下它的思想。
注意事项:实现交换要增设变量,使用数组不能越界,如果弄不懂可以画个流程图
参考代码:思路一:
#include<stdio.h>
int main()
{
int a,b,c,max,t;
scanf("%d%d%d",&a,&b,&c);
if(a<b)
max=b;
else
max=a;
if(max<c)
{
t=c;
c=max;
max=t;
}
printf("%d",max);
return 0;
}
思路二:
#include<stdio.h>
int main()
{
int a,b,c,max;
scanf("%d%d%d",&a,&b,&c);
max=a;
if(max<b)
max=b;
if(max<c)
max=c;
printf("%d",max);
return 0;
}
思路三(由于超时无法通过,但效果一样,可推广到四个数找最大值)
#include<stdio.h>
int main()
{
int a[3];
int temp;
scanf("%d%d%d",&a[0],&a[1],&a[2]);
for(int i=0;i<3;i++)
for(int j=0;j<3-i;j++)
if(a[j]<a[j+1])
{
temp=a[j+1];
a[j+1]=a[j];
a[j]=temp;
}
printf("%d",a[0]);
return 0;
}
0.0分
2 人评分
冒泡排序来凑热闹了(虽然很繁琐、有点落后) #include<stdio.h> void main() { int a,b,c,d; scanf("%d%d%d",&a,&b,&c); if(a>b) if(b>c) d=a; else if(a>c) d=a; else d=c; else if(a>c) d=b; else if(b>c) d=b; else d=c; printf("%d\n",d); }
上车人数 (C语言代码)浏览:1173 |
2004年秋浙江省计算机等级考试二级C 编程题(2) (C语言代码)浏览:667 |
C语言考试练习题_排列 (C++代码)浏览:628 |
C二级辅导-进制转换 (C语言代码)浏览:615 |
C语言训练-计算t=1+1/2+1/3+...+1/n (C语言代码)浏览:859 |
【绝对值排序】 (C语言代码)浏览:713 |
【蟠桃记】 (C语言代码)浏览:648 |
不会做的浏览:871 |
WU-蓝桥杯算法提高VIP-Quadratic Equation (C++代码)浏览:1742 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:1144 |