665. 非遞減數(shù)列

內(nèi)容

給定一個(gè)長(zhǎng)度為 n 的整數(shù)數(shù)組猎贴,你的任務(wù)是判斷在最多改變 1 個(gè)元素的情況下弃酌,該數(shù)組能否變成一個(gè)非遞減數(shù)列犬第。
我們是這樣定義一個(gè)非遞減數(shù)列的: 對(duì)于數(shù)組中所有的 i (1 <= i < n)荸哟,滿足 array[i] <= array[i + 1]。

示例 1:

輸入: [4,2,3]
輸出: True
解釋: 你可以通過(guò)把第一個(gè)4變成1來(lái)使得它成為一個(gè)非遞減數(shù)列瞬捕。
示例 2:

輸入: [4,2,1]
輸出: False
解釋: 你不能在只改變一個(gè)元素的情況下將其變?yōu)榉沁f減數(shù)列鞍历。
說(shuō)明: n 的范圍為 [1, 10,000]。


思路

既然是要做成一個(gè)非遞減數(shù)列肪虎,那么就是 i1<=i2<=i3
如果不滿足的話劣砍,那就需要分情況討論,以下是不滿足的所有組合:

  1. i1>i2<=i3
    這種情況直接讓i1=i2即可扇救,
    因?yàn)椴还躨1>i3還是i1<i3只要滿足i1<=i2即可

2刑枝、 i1>i2>i3
這種情況無(wú)解

3、 i1<=i2>i3
假設(shè)有i1<=i2>i3<=i4
然后這里可能需要分兩種情況:
1. 如果i1<i3迅腔,同時(shí)i3需要>=i2装畅,也就是i1<=i2<=i3<=i4,然而事實(shí)是i3<i2沧烈,如果將i3=i2掠兄,那么i3會(huì)比之前變大,很可能會(huì)出現(xiàn)i3>i4的情況锌雀,所以這里只能選擇將i2變小蚂夕,因?yàn)閕3也大于i1,所以i2變成i3還是能滿足i2>=i1的條件腋逆。
2. 如果i1>i3婿牍,那么i3也要滿足>=i2,所以這里只能i3=i2


代碼

/**
 * @param {number[]} nums
 * @return {boolean}
 */
var checkPossibility = function (nums) {
    var changeCount = 0;
    for (var i = 0; i < nums.length; i++) {
        var last = nums[i - 1] || -(Math.pow(2, 31) + 100);
        var next = nums[i + 1] || Math.pow(2, 31) + 100;

        if (last <= nums[i] && nums[i] > next) {
            if (changeCount > 0) return false;

            if (last < next) {
                nums[i] = next;
            } else {
                nums[i + 1] = nums[i];
            }

            changeCount++;
            i = -1;
        }

        if (last > nums[i] && nums[i] > next) {
            return false;
        }

        if (last > nums[i] && nums[i] <= next) {
            if (changeCount > 0) return false;
            nums[i] = last;
            changeCount++;
            i = -1;
        }
    }

    return true;
};

回到目錄

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末惩歉,一起剝皮案震驚了整個(gè)濱河市等脂,隨后出現(xiàn)的幾起案子俏蛮,更是在濱河造成了極大的恐慌,老刑警劉巖慎菲,帶你破解...
    沈念sama閱讀 218,284評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件嫁蛇,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡露该,警方通過(guò)查閱死者的電腦和手機(jī)睬棚,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)解幼,“玉大人抑党,你說(shuō)我怎么就攤上這事∧彀冢” “怎么了底靠?”我有些...
    開封第一講書人閱讀 164,614評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)特铝。 經(jīng)常有香客問(wèn)我暑中,道長(zhǎng),這世上最難降的妖魔是什么鲫剿? 我笑而不...
    開封第一講書人閱讀 58,671評(píng)論 1 293
  • 正文 為了忘掉前任鳄逾,我火速辦了婚禮,結(jié)果婚禮上灵莲,老公的妹妹穿的比我還像新娘雕凹。我一直安慰自己,他們只是感情好政冻,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,699評(píng)論 6 392
  • 文/花漫 我一把揭開白布枚抵。 她就那樣靜靜地躺著,像睡著了一般明场。 火紅的嫁衣襯著肌膚如雪汽摹。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,562評(píng)論 1 305
  • 那天苦锨,我揣著相機(jī)與錄音竖慧,去河邊找鬼。 笑死逆屡,一個(gè)胖子當(dāng)著我的面吹牛圾旨,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播魏蔗,決...
    沈念sama閱讀 40,309評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼砍的,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了莺治?” 一聲冷哼從身側(cè)響起廓鞠,我...
    開封第一講書人閱讀 39,223評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤帚稠,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后床佳,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體滋早,經(jīng)...
    沈念sama閱讀 45,668評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,859評(píng)論 3 336
  • 正文 我和宋清朗相戀三年砌们,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了杆麸。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,981評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡浪感,死狀恐怖昔头,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情影兽,我是刑警寧澤,帶...
    沈念sama閱讀 35,705評(píng)論 5 347
  • 正文 年R本政府宣布捐名,位于F島的核電站桐筏,受9級(jí)特大地震影響梅忌,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜踱葛,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,310評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望盯另。 院中可真熱鬧商蕴,春花似錦绪商、人聲如沸腹殿。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至旺嬉,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間雨效,已是汗流浹背徽龟。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工耘沼, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留菠隆,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,146評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像校仑,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子传惠,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,933評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容