本题要求编写程序,找出给定的n个数中的最大值及其对应的最小下标(下标从0开始)。
输入格式:
输入在第一行中给出一个正整数n(1<n≤10)。第二行输入n个整数,用空格分开。
输出格式:
在一行中输出最大值及最大值的最小下标,中间用一个空格分开。
输入样例:
6
2 8 10 1 9 10
输出样例:
10 2
想法:修改了前面的步骤,先得到n的值再定义a[n] ,而不是直接定义a[10](之前有道类似的题可以这样,在这里不行),中心思想就是一堆数据找最大数的方法,再拿一个变量来记录此时的下标,注意是最小下标。
#include<stdio.h>
int main()
{
int n,i,max,j=0;//记录下标的j一开始必须赋0的初值,否则在a[0]最大的情况不会进行循环,j不会被赋值
scanf("%d\n",&n);
int a[n];//先确定n再定义a[n]
for(i=0;i<n;i++)
{
scanf("%d",&a[i]);//储存输入的数
}
max=a[0];//这个定义不能在循环内,否则每一次循环开始的max都是a[0],哪怕之前找到了一个也会被覆盖
for(i=0;i<n;i++)
{
if(a[i]>max)
{
max=a[i];
j=i;
}
}
printf("%d %d",max,j);
return 0;
}
提炼:两个开始忽略的细节,1.max赋初值要在循环外,否则每次循环开始max的值都一样,可能覆盖之前的成果 2.j(记录最小下标的变量)的赋初值也要在循环外,若只在循环内有赋值操作的话,当a[0]就是最大值的时候就会导致j始终没有被赋值,自然无法输出。
二周目时忽略了J要赋初值=0以此解决A[0]即最大值的情况。