#include
int main()
{
int i,j,a[10],max;
for(i = 0;i < 10;i++)
scanf("%d",&a[i]);
max = a[0];
for (j = 0;j < 10;j++)
{
if (a[j]>max)
max=a[j];
}
printf("max=%d\n",max);
return 0;
}
LZ看我写的这个OK不?
不懂请追问,望采纳~~
你给的程序都对的。先将第个输入的数赋给最大值,是为了少一次比较,你可以将最大值赋为0,然后每次输入数时都与最大值比较,若新输入的数较大,则更新最大值。
//我正在机房上课,已通过验证(c99标准的)
#include
#define N 10
int s[N];
int f(int n){
return n == 1 ? max(s[0], s[1]) : max(f(n-1), s[n]);
}
int max(int a, int b){
return a >= b ? a : b;
}
int main(){
for(int i = 0; i < 10; i++){ //这个你可以把 i 声明在外边否则用gcc编译的话要加 -std=c99
scanf("%d", &s[i]);
}
printf("%d", f(N-1));
return 0;
}
#include
int main()
{
int i,j,a[10],max;
for(i = 0;i < 10;i++)
scanf("%d",&a[i]);
max = a[0];
for (j = 0;j < 10;j++)
{
if (a[j]>max)
max=a[j];
}
printf("max=%d\n",max);
return 0;
}
#include
void main()
{
int n,a,max;
n=1;
scanf("%d",&max);
while (n<10)
{
scanf("%d",&a);
if (a>max) max=a;
n=n+1;
}
printf("%d",max);
}