力扣:2210. 统计数组中峰和谷的数量

目录

一.题目

二.解题思路

三.代码

四.题后语


一.题目

        1.题目详情

        给你一个下标从 0 开始的整数数组 nums 。如果两侧距 i 最近的不相等邻居的值均小于 nums[i] ,则下标 i 是 nums 中,某个峰的一部分。类似地,如果两侧距 i 最近的不相等邻居的值均大于 nums[i] ,则下标 i 是 nums 中某个谷的一部分。对于相邻下标 i 和 j ,如果 nums[i] == nums[j] , 则认为这两下标属于 同一个 峰或谷。

        注意,要使某个下标所做峰或谷的一部分,那么它左右两侧必须  存在不相等邻居。

        要求:返回 nums 中峰和谷的数量。

示例 1:

输入:nums = [2,4,1,1,6,5]
输出:3
解释:
在下标 0 :由于 2 的左侧不存在不相等邻居,所以下标 0 既不是峰也不是谷。
在下标 1 :4 的最近不相等邻居是 2 和 1 。由于 4 > 2 且 4 > 1 ,下标 1 是一个峰。
在下标 2 :1 的最近不相等邻居是 4 和 6 。由于 1 < 4 且 1 < 6 ,下标 2 是一个谷。
在下标 3 :1 的最近不相等邻居是 4 和 6 。由于 1 < 4 且 1 < 6 ,下标 3 符合谷的定义,但需要注意它和下标 2 是同一个谷的一部分。
在下标 4 :6 的最近不相等邻居是 1 和 5 。由于 6 > 1 且 6 > 5 ,下标 4 是一个峰。
在下标 5 :由于 5 的右侧不存在不相等邻居,所以下标 5 既不是峰也不是谷。
共有 3 个峰和谷,所以返回 3 。

2210. 统计数组中峰和谷的数量 - 力扣(Leetcode)https://leetcode.cn/problems/count-hills-and-valleys-in-an-array/description/

二.解题思路

        1.通过for循环遍历数组

        2.通过while判断数值是否一致

        3.判断是否为锋或谷

        4.i直接跳到j所在的位置

        5.返回结果

三.代码

class Solution {
    public int countHillValley(int[] nums) {
        int len=nums.length;
        int ans=0;
        for(int i=1;i<len-1;){
            int j=i+1;
            while(nums[i]==nums[j]&&j<len-1)j++;
            if(nums[i-1]<nums[i]&&nums[j]<nums[i])
                ans+=1;
            if(nums[i-1]>nums[i]&&nums[j]>nums[i])
                ans+=1;
            i=j;
        }
        return ans;
    }
}

四.题后语(

         这到题没什么,只要根据题意来设置几个判断就可以了,然后比较值得注意的地方就是连续相同数值的时候,这里我用的是while来让j往下走,然后走到第一个不同的就退出来进行峰谷判断,随后让i直接到j,这样就保证了i的前一个一定是上一个不同的数据,然后就只要往后找不同的数据就好了,最后j是要小于len-1的且i也是从1开始,因为数组的开头和末尾必不可能是一个锋或谷在这道题里面。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值