玩命加载中 . . .

打印极值点下标


http://t.cn/E9ehDw4

描述

在一个整数数组上,对于下标为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
#define _CRT_SECURE_NO_WARNINGS 1
#include <bits/stdc++.h>
using namespace std;

const int N = 90;
int arr[N];

int main() {
	int n;
	while (cin >> n)
	{
		for (int i = 0; i < n; ++i)
			cin >> arr[i];
		if (arr[0] != arr[1])//首数
			printf("%d ", 0);
		for (int i = 1; i < n - 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[n - 2] != arr[n - 1])
			printf("%d ", n-1);
		printf("\n");
	}
	return 0;
}

文章作者: Jack Tim
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 Jack Tim !
评论
  目录