[数组基础]峰值

题目描述

输入 N 个整数,表示股票指数的N个时刻的值,如果有一个时刻的值比前一刻和后一刻的值都 大,就称为一个高峰值,计算共有多少个高峰? 注:第1个和最后一个值不能算高峰。

输入格式

第一行1个整数n,范围在[1,100]。 第二行有n个[1,10000]范围的整数,整数间用一个空格分隔。

输出格式

只一个整数,高峰的个数。

样例输入/输出

输入数据 1

复制代码
7
7  12  8  8  5  6  4

输出数据 1

复制代码
2

解题思路:

题目要求计算给定股票指数序列中的高峰值个数。高峰值定义为一个时刻的值比前一刻和后一刻 的值都大,但第一个和最后一个值不能算作高峰值。

解题思路:

  1. 定义一个整型数组a来存储输入的股票指数序列。

  2. 使用一个循环将输入的股票指数逐个存入数组a中。

  3. 使用一个循环遍历数组a的第2个元素到倒数第2个元素,判断是否为高峰值。

  4. 如果当前元素a[i]比前一元素a[i-1]和后一元素a[i+1]都大,则计数器s加1。

  5. 循环结束后,输出计数器s的值,即高峰值的个数。

C++代码如下:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main(){ 
    long long n,a[100+5],s=0;
    cin>>n;
	for(int i=1;i<=n;i++)
	{
		cin>>a[i];
	}
	for(int i=2;i<n;i++)
	{
		if(a[i]>a[i+1]&&a[i]>a[i-1])
		s++;
	}	
		
	cout<<s;
    return 0;
}

复杂度分析:

  • 时间复杂度:O(n),其中n为输入的整数个数,需要遍历一次数组a。

  • 空间复杂度:O(n),需要使用一个大小为n的数组a来存储输入的整数序列。

点个赞吧,帅哥美女们,本人为小学生。

相关推荐
智者知已应修善业7 小时前
【51单片机89C51及74LS273、74LS244组成】2022-5-28
c++·经验分享·笔记·算法·51单片机
Byron Loong10 小时前
【c++】为什么有了dll和.h,还需要包含lib
java·开发语言·c++
坚果派·白晓明10 小时前
【鸿蒙PC三方库移植适配框架解读系列】第一篇:Lycium C/C++ 三方库适配 — 概述与环境配置
c语言·开发语言·c++·harmonyos·开源鸿蒙·三方库·c/c++三方库
咩咦11 小时前
C++学习笔记02:cin 和 cout 输入输出
c++·学习笔记·cin·输入输出·cout
咩咦11 小时前
C++学习笔记05:引用和常引用
c++·学习笔记·引用·const·常引用
香蕉鼠片12 小时前
算法过程中不会的
开发语言·c++
阿旭超级学得完12 小时前
C++11包装器(function和bind)
java·开发语言·c++·算法·哈希算法·散列表
li星野12 小时前
位运算 & 数学 & 高频进阶九题通关(Python + C++)
c++·python·学习·算法
磊 子12 小时前
多态类原理+四种类型转换+异常处理
开发语言·c++·算法
王老师青少年编程12 小时前
csp信奥赛C++高频考点专项训练之字符串 --【回文字符串】:回文拼接
c++·字符串·csp·高频考点·信奥赛·字符串回文·回文拼接