求最大值及其下标
本题要求编写程序,找出给定的n个数中的最大值及其对应的最小下标(下标从0开始)。
输入格式:
输入在第一行中给出一个正整数n(1<n≤10)。第二行输入n个整数,用空格分开。
输出格式:
在一行中输出最大值及最大值的最小下标,中间用一个空格分开。
输入样例:
6
2 8 10 1 9 10
输出样例:
10 2
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
int n, i, max, k;
scanf("%d", &n);
int a[11];
memset(a, 0, sizeof(a));
for(i = 0; i < n; i++)
{
scanf("%d", &a[i]);
}
max = a[0];//用“打擂法”,先将a[0]作为擂主
k = 0;//记得k要赋值到max赋值所在的下标
for(i = 1; i < n; i++)
{
if(max < a[i])
{//注意此处的应为 "<",不能加 "=",
否则i将会被后面和max相同值的数所在的下标代替,即不为“最小下标”
max = a[i];
k = i;
}
}
printf("%d %d\n", max, k);
return 0;
}
这道题我修改了好多遍,最后才得出最完善的答案。
本题有几处需要注意的地方:
max = a[0];//用“打擂法”,先将a[0]作为擂主
k = 0;//记得k要赋值到max赋值所在的下标
这两处都要赋值
if(max < a[i])
{//注意此处的应为 “<”,不能加 “=”,
否则i将会被后面和max相同值的数所在的下标代替,即不为“最小下标”