吴筱


私信TA

用户名:uq_17393392938

访问量:2682

签 名:

世间风物论自由,喜一生我有,共四海丰收

等  级
排  名 13199
经  验 878
参赛次数 0
文章发表 5
年  龄 18
在职情况 学生
学  校 安徽工程大学
专  业 数据科学与大数据技术

  自我简介:

安徽工程大学20级学生,计算机小白一个

解题思路:思路一:用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 人评分

  评论区

第二个可以运行,但是无论输入什么数,最后的结果都是2031646
2021-11-11 20:35:28
第二个运行不了
2021-03-15 11:48:18
冒泡排序来凑热闹了(虽然很繁琐、有点落后)
#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);
}
2021-01-25 22:29:48
  • «
  • 1
  • »