解题思路:思路一:用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语言训练-角谷猜想 (C语言代码)浏览:1424 |
C语言程序设计教程(第三版)课后习题11.12 (C语言代码)浏览:717 |
最小公倍数 (C语言代码)浏览:861 |
蛇行矩阵 (C语言代码)浏览:742 |
C语言程序设计教程(第三版)课后习题6.11 (C语言代码)浏览:549 |
【偶数求和】 (C语言代码)浏览:556 |
C语言程序设计教程(第三版)课后习题3.7 (C语言代码)浏览:840 |
哥德巴赫曾猜测 (C语言代码)浏览:2314 |
Hello, world! (C语言代码)浏览:714 |
有关字符,字符串的输入输出函数说明浏览:477 |