首页 > 其他 > 详细

941. Valid Mountain Array

时间:2020-11-04 10:07:26      阅读:43      评论:0      收藏:0      [点我收藏+]

题目描述

Given an array A of integers, return true if and only if it is a valid mountain array.

Recall that A is a mountain array if and only if:

A.length >= 3
There exists some i with 0 < i < A.length - 1 such that:
A[0] < A[1] < ... A[i-1] < A[i]
A[i] > A[i+1] > ... > A[A.length - 1]

解决思路

从数组的最左侧开始向右扫描,直到找到第一个不满足A[i]<A[i+1]的下标i,那么i就是这个数组的最高点的下标。如果i=0或者不存在这样的i(即整个数组都是单调递增的),那么就返回false。否则从i开始继续向右扫描,判断接下来的的下标j是否都满足 A[j]>A[j+1],若都满足就返回true,否则返回false。

class Solution {
    public boolean validMountainArray(int[] A) {
        int N = A.length;
        int i = 0;

        // 递增扫描
        while (i + 1 < N && A[i] < A[i + 1]) {
            i++;
        }

        // 最高点不能是数组的第一个位置或最后一个位置
        if (i == 0 || i == N - 1) {
            return false;
        }

        // 递减扫描
        while (i + 1 < N && A[i] > A[i + 1]) {
            i++;
        }

        return i == N - 1;
    }
}
class Solution {
    public boolean validMountainArray(int[] A) {
        int len = A.length;
        if (len < 3) {
            return false;
        }

        int pos=1;
        while(pos < len) {
            if (A[pos-1] < A[pos]) {
                ++pos;
            } else {
                break;
            }
        }
        
        if (pos == 1 || pos == len) {
            return false;
        }

        while (pos < len) {
            if (A[pos-1] > A[pos]) {
                ++pos;
            } else {
                return false;
            }
        }
        
        return pos==len;
    }
}

941. Valid Mountain Array

原文:https://www.cnblogs.com/hunter-w/p/13923587.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!