Leetcode941. 有效的山脉数组

941. 有效的山脉数组

Difficulty: 简单

给定一个整数数组 A,如果它是有效的山脉数组就返回 true,否则返回 false

让我们回顾一下,如果 A 满足下述条件,那么它是一个山脉数组:

  • A.length >= 3
  • 0 < i < A.length - 1 条件下,存在 i 使得:
    • A[0] < A[1] < ... A[i-1] < A[i]
    • A[i] > A[i+1] > ... > A[A.length - 1]

示例 1:

输入:[2,1]
输出:false

示例 2:

输入:[3,5,5]
输出:false

示例 3:

输入:[0,3,2,1]
输出:true

提示:

  1. 0 <= A.length <= 10000
  2. 0 <= A[i] <= 10000
解法1

模拟法( 分类讨论辣鸡->面向测试用例编程

class Solution(object):
    def validMountainArray(self, A):
        """
        :type A: List[int]
        :rtype: bool
        """
        top=-1
        if len(A)<3:
            return False
        for i in range(len(A)-1):#上升阶段,找山顶
            if A[i]==A[i+1]:
                return False
            if A[i]>A[i+1]:
                top=i
                break
        if top==0 or top==-1:
            return False
        #下降
        for i in range(top,len(A)-1):
            if A[i]<=A[i+1]:
                return False
        return True
解法2

双指针,更好理解。。两端的指针都向中间走,走到不能走,看是不是走到一块去了(同时不能有一个指针没动,这样是斜坡)

另外用这个秒掉 852. 山脉数组的峰顶索引

class Solution(object):
    def validMountainArray(self, arr):
        """
        :type arr: List[int]
        :rtype: bool
        """
        l=len(arr)
        i=0
        j=l-1
        while i<l-1 and arr[i]<arr[i+1]:
            i+=1
        while j>0 and arr[j]<arr[j-1]:
            j-=1
        return True if (i==j and i!=0 and j!=l-1)else False
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值