zoukankan      html  css  js  c++  java
  • 845. Longest Mountain in Array

    Let's call any (contiguous) subarray B (of A) a mountain if the following properties hold:

    • B.length >= 3
    • There exists some 0 < i < B.length - 1 such that B[0] < B[1] < ... B[i-1] < B[i] > B[i+1] > ... > B[B.length - 1]

    (Note that B could be any subarray of A, including the entire array A.)

    Given an array A of integers, return the length of the longest mountain

    Return 0 if there is no mountain.

    Example 1:

    Input: [2,1,4,7,3,2,5]
    Output: 5
    Explanation: The largest mountain is [1,4,7,3,2] which has length 5.
    

    Example 2:

    Input: [2,2,2]
    Output: 0
    Explanation: There is no mountain.
    

    Note:

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

    Follow up:

    • Can you solve it using only one pass?
    • Can you solve it in O(1) space?
    class Solution {
        public int longestMountain(int[] A) {
                int n=A.length;
                if(n<3)return 0;
    
                int left=0;int right;int max=0;
    
                while(left<n-2){
                    //skip decending and equal array
                    while(left<n-1 && A[left]>=A[left+1]){
                        left++;
                    }
                    right=left+1;
                    //mountain up
                    while(right<n-1 && A[right]<A[right+1]){
                        right++;
                    }
                    //mountain down
                    while(right<n-1 && A[right]>A[right+1]){
                        right++;
                        //update the max value
                        max=Math.max(max,right-left+1);
                    }
                    left=right;
                }
                return max;
            }
    }

    好耶

  • 相关阅读:
    Authentication with SignalR and OAuth Bearer Token
    [Web API] 如何让 Web API 统一回传格式以及例外处理[转]
    EF6 Database First (DbContext)
    DbContext运行时动态附加上一个dbset
    命令模式
    责任链模式
    策略模式
    Sql Server isnull() 用法
    状态者模式
    dom元素改变监听
  • 原文地址:https://www.cnblogs.com/wentiliangkaihua/p/13993868.html
Copyright © 2011-2022 走看看