溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

php中的山脈數(shù)組是什么

發(fā)布時(shí)間:2021-07-07 17:31:18 來源:億速云 閱讀:133 作者:chen 欄目:編程語言

本篇內(nèi)容主要講解“php中的山脈數(shù)組是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“php中的山脈數(shù)組是什么”吧!

在php中,不知你有沒有聽過這樣一個(gè)數(shù)組叫做山脈數(shù)組。今天我們就來好好介紹一下山脈數(shù)組,有需要的小伙伴可以參考參考。

有效的山脈數(shù)組

給定一個(gè)整數(shù)數(shù)組 A,如果它是有效的山脈數(shù)組就返回 true,否則返回 false。

讓我們回顧一下,如果 A 滿足下述條件,那么它是一個(gè)山脈數(shù)組:

php中的山脈數(shù)組是什么

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

提示:

  • 0 <= A.length <= 10000

  • 0 <= A[i] <= 10000

解題思路

雙指針一個(gè)從前往后跑,一個(gè)從后往前跑,最終能相遇在中間就可以。

注意臨界條件: 如果 left 或者 right 沒有移動(dòng),說明是一個(gè)單調(diào)遞增或者遞減的數(shù)組,依然不是山峰。

class Solution {
    /** * @param Integer[] $A * @return Boolean */
    function validMountainArray($A) {
        if (count($A) < 3) return false;
        $left = 0;
        $right = count($A) - 1;
        // 注意防止越界
        while ($left < count($A) - 1 && $A[$left] < $A[$left + 1]) $left++;
        // 注意防止越界
        while ($right > 0 && $A[$right] < $A[$right - 1]) $right--;
        // 如果left或者right都在起始位置,說明不是山峰
        if ($left == $right && $left != 0 && $right != count($A) - 1) return true;
        return false;
    }}

到此,相信大家對(duì)“php中的山脈數(shù)組是什么”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI