website/content/ChapterFour/0800~0899/0845.Longest-Mountain-in-Array.md
Let's call any (contiguous) subarray B (of A) a mountain if the following properties hold:
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:
Follow up:
这道题考察的是滑动窗口的问题。
给出一个数组,要求求出这个数组里面“山”最长的长度。“山”的意思是,从一个数开始逐渐上升,到顶以后,逐渐下降。
这道题解题思路也是滑动窗口,只不过在滑动的过程中多判断一个上升和下降的状态即可。
package leetcode
func longestMountain(A []int) int {
left, right, res, isAscending := 0, 0, 0, true
for left < len(A) {
if right+1 < len(A) && ((isAscending == true && A[right+1] > A[left] && A[right+1] > A[right]) || (right != left && A[right+1] < A[right])) {
if A[right+1] < A[right] {
isAscending = false
}
right++
} else {
if right != left && isAscending == false {
res = max(res, right-left+1)
}
left++
if right < left {
right = left
}
if right == left {
isAscending = true
}
}
}
return res
}