描述:
在一个整数数组上,对于下标为i的整数,如果它大于所有它相邻的整数, 或者小于所有它相邻的整数,则称该整数为一个极值点,极值点的下标就是i。
输入描述:
每个案例第一行为此数组元素个数k(4<k<80),第二行是k个整数,每两个整数之间用空格分隔
输出描述:
每个案例输出为n个数字(其中n为该案例中极值点的个数):每个数字对应相应数组的相应极值点下标值,下标值之间用空格分隔。
示例1
输入:
10
10 12 12 11 11 12 23 24 12 12
15
12 12 122 112 222 211 222 221 76 36 31 234 256 76 76
15
12 14 122 112 222 222 222 221 76 36 31 234 256 76 73
输出:
0 7
2 3 4 5 6 10 12
0 2 3 10 12 14
知识点: 查找
AC代码:
c
#include <stdio.h>
int main() {
int k;
int arr[85];
while(scanf("%d", &k) != EOF) {
for(int i = 0; i < k; i ++)
scanf("%d", &arr[i]);
if(arr[0] != arr[1])
printf("0 ");
for(int i = 1; i < k - 1; i++)
if((arr[i] > arr[i - 1] && arr[i] > arr[i + 1]) || (arr[i] < arr[i - 1] && arr[i] < arr[i + 1]))
printf("%d ", i);
if(arr[k - 1] != arr[k - 2])
printf("%d", k - 1);
printf("\n");
}
return 0;
}