[讨论]这句代码可以用更简单的FOR来写吗?
#include <stdio.h>main ()
{
int a[10], i;
for ( i=0; i<10; i++ )
{
scanf("%d",&a[i]);
}
printf("%d\n",max(a[9],max(a[8],max(a[7],max(a[6],max(a[5],max(a[4],max(a[3],max(a[2],max(a[0],a[1]))))))))));
} //里面max这一长句可以单独用一个for话句实现吗?谢谢。
int max ( int x, int y)
{
int z;
return ( z = x > y ? x : y );
}
----------------解决方案--------------------------------------------------------
楼主可以用冒泡法求最大值啊
程序代码:
#include <stdio.h>
#define NUM 100
void main()
{
int n, i, j, tmp, a[NUM];
printf("请输入比较个数:\n");
scanf("%d", &n);
printf("开始输入:");
for(i = 0; i < n; i++)
{
scanf("%d", &a[i]);
}
for(j = 0; j < n - 1; j++)
{
for(i = 0; i < n - j - 1; i++)
{
if(a[i] < a[i + 1])
{
tmp = a[i];
a[i] = a[i+1];
a[i+1] = tmp;
}
}
}
printf("%d\n", a[0]);
}
#define NUM 100
void main()
{
int n, i, j, tmp, a[NUM];
printf("请输入比较个数:\n");
scanf("%d", &n);
printf("开始输入:");
for(i = 0; i < n; i++)
{
scanf("%d", &a[i]);
}
for(j = 0; j < n - 1; j++)
{
for(i = 0; i < n - j - 1; i++)
{
if(a[i] < a[i + 1])
{
tmp = a[i];
a[i] = a[i+1];
a[i+1] = tmp;
}
}
}
printf("%d\n", a[0]);
}
----------------解决方案--------------------------------------------------------
楼主函数学得太好了!有才!
----------------解决方案--------------------------------------------------------
int a[10], i;
for ( i=0; i<10; i++ )
{
scanf("%d",&a[i]);
}
max=a[0];
for (i=1; i!=9; ++i)
{
max=max>a[i]?max:a[i];
}
printf("%d\n",max);
----------------解决方案--------------------------------------------------------
输出语句里那一大堆是什么?我真是看不懂。
----------------解决方案--------------------------------------------------------
数组取最大的输出
LZ实在有才,如果A[100]不晓得他怎么写
----------------解决方案--------------------------------------------------------
二楼跟四楼的方法我都会的,并且也写过二楼跟四楼一样的代码。
现在学到函数一章,所以想写写有关函数的代码。
写到这一句时
printf("%d\n",max(a[9],max(a[8],max(a[7],max(a[6],max(a[5],max(a[4],max(a[3],max(a[2],max(a[0],a[1]))))))))));
}
觉得这一句应该的后面max 部分是有规律的,应该可以用一个for语句来实现,可是想了一个多小时也想不出来怎样用for语句来写后面部分,所以才有发此贴的意思。
----------------解决方案--------------------------------------------------------
#include <stdio.h>
main ()
{
int a[10], i, maxnum;
for ( i=0; i<10; i++ )
{
scanf("%d",&a[i]);
}
maxnum = a[0];
for ( i=1; i!=10; i++ )
{
maxnum = max ( maxnum, a[i] );
}
printf("%d\n",maxnum);
}
int max ( int x, int y)
{
int z;
return ( z = x > y ? x : y );
}
中间的max语句可以改成上面的for,终于有高人搞定,谢谢。
----------------解决方案--------------------------------------------------------
#include <stdio.h>
int main(void)
{
int a[10], i,maxt;
for ( i=0; i<10; i++ )
{
scanf("%d",&a[i]);
}
maxt=a[0];
for(i=1;i<10;i++) maxt=max(a[i],maxt);
printf("%d\n",maxt);
return 0;
}
int max ( int x, int y)
{
int z;
return ( z = x > y ? x : y );
}
----------------解决方案--------------------------------------------------------
#include <stdio.h>
int max ( int x[], int size)
{
int z = 0, i;
for (i=0; i<size; ++i)
if (x[i] > z)
z = x[i];
return z;
}
int main ()
{
int a[10], i;
for ( i=0; i<10; i++ )
scanf("%d", &a[i]);
printf("%d", max(a, 10));
return 0;
}
这种方法更高明,让我受教了。
----------------解决方案--------------------------------------------------------