【LeetCode分享】26. 刪除有序數(shù)組中的重復(fù)項(xiàng)

題目描述 26. 刪除有序數(shù)組中的重復(fù)項(xiàng)

給你一個(gè)有序數(shù)組nums 牍汹,請(qǐng)你原地刪除重復(fù)出現(xiàn)的元素砂心,使每個(gè)元素 只出現(xiàn)一次 彻秆,返回刪除后數(shù)組的新長度楔绞。
不要使用額外的數(shù)組空間,你必須在原地修改輸入數(shù)組 并在使用O(1)額外空間的條件下完成唇兑。

說明:
為什么返回?cái)?shù)值是整數(shù)酒朵,但輸出的答案是數(shù)組呢?
請(qǐng)注意,輸入數(shù)組是以「引用」方式傳遞的扎附,這意味著在函數(shù)里修改輸入數(shù)組對(duì)于調(diào)用者是可見的蔫耽。
你可以想象內(nèi)部操作如下:

// nums 是以“引用”方式傳遞的。也就是說留夜,不對(duì)實(shí)參做任何拷貝
int len = removeDuplicates(nums);

// 在函數(shù)里修改輸入數(shù)組對(duì)于調(diào)用者是可見的匙铡。
// 根據(jù)你的函數(shù)返回的長度, 它會(huì)打印出數(shù)組中 該長度范圍內(nèi) 的所有元素。
for (int i = 0; i < len; i++) {
    print(nums[i]);
}
示例1
輸入:nums = [1,1,2]
輸出:2, nums = [1,2]
解釋:函數(shù)應(yīng)該返回新的長度 2 碍粥,并且原數(shù)組 nums 的前兩個(gè)元素被修改為 1, 2 鳖眼。不需要考慮數(shù)組中超出新長度后面的元素。

示例2
輸入:nums = [0,0,1,1,1,2,2,3,3,4]
輸出:5, nums = [0,1,2,3,4]
解釋:函數(shù)應(yīng)該返回新的長度 5 嚼摩, 并且原數(shù)組 nums 的前五個(gè)元素被修改為 0, 1, 2, 3, 4 钦讳。不需要考慮數(shù)組中超出新長度后面的元素。

提示:

  • 0 <= nums.length <= 3 * 104
  • -104 <= nums[i] <= 104
  • nums 已按升序排列

思路1 刪除數(shù)組元素

我們可以對(duì)數(shù)組進(jìn)行遍歷枕面,記錄一個(gè)唯一值uniq=nums[0]愿卒。

  1. 當(dāng)遍歷的元素不等于該唯一值時(shí),我們將唯一值指針右移膊畴。
  2. 當(dāng)遍歷的元素等于唯一值時(shí)掘猿,說明是重復(fù)元素,此時(shí)刪掉重復(fù)元素唇跨。
  3. 當(dāng)遍歷結(jié)束時(shí)稠通,得到新的數(shù)組,返回該數(shù)組長度即可买猖。

代碼實(shí)現(xiàn)

/**
 * 刪除數(shù)組元素的方式
 * @param {number[]} nums
 * @return {number}
 */
var removeDuplicates = function (nums) {
    if (nums == null || nums.length === 0)
        return 0
    let i = 1
    while (i < nums.length) {
        if(nums[i-1] === nums[i]) {
            nums.splice(i, 1)
        }else {
            i++
        }
    }
    return nums.length
};

思路2 不刪除數(shù)組元素

我們同樣可以用兩個(gè)指針slow = 0fast = 1改橘,其中fast指針遍歷數(shù)組,slow指針指向需要被覆蓋的不重復(fù)元素的位置玉控。

  1. 當(dāng)判斷nums[fast] !== nums[slow]的時(shí)候飞主,說明出現(xiàn)了不重復(fù)元素,此時(shí)進(jìn)行覆蓋nums[++slow] = nums[fast]
  2. 當(dāng)判斷nums[fast] === nums[slow]時(shí)候,說明是重復(fù)元素碌识,只需要將fast指針右移即可碾篡。
  3. 當(dāng)遍歷結(jié)束后,返回slow指針的下一個(gè)位置(數(shù)組長度=指針位置+1)

代碼實(shí)現(xiàn)

/**
 * 雙指針
 * @param {number[]} nums
 * @return {number}
 */
var removeDuplicates = function (nums) {
    if (nums == null || nums.length === 0) {
        return 0
    }
    const n = nums.length
    let slow = 0, fast = 1
    while (fast < n) {
        if (nums[slow] !== nums[fast]) {
            nums[++slow] = nums[fast]
        }
        fast++
    }
    return slow + 1
}

結(jié)語

由于思路2雙指針只是對(duì)數(shù)組元素進(jìn)行覆蓋筏餐,而非思路1中采用Array.splice()方法對(duì)數(shù)組元素進(jìn)行刪除开泽,效率極大提升,推薦使用魁瞪。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末穆律,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子导俘,更是在濱河造成了極大的恐慌峦耘,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,366評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件旅薄,死亡現(xiàn)場(chǎng)離奇詭異辅髓,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)少梁,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門利朵,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人猎莲,你說我怎么就攤上這事绍弟。” “怎么了著洼?”我有些...
    開封第一講書人閱讀 165,689評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵樟遣,是天一觀的道長。 經(jīng)常有香客問我身笤,道長豹悬,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,925評(píng)論 1 295
  • 正文 為了忘掉前任液荸,我火速辦了婚禮瞻佛,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘娇钱。我一直安慰自己伤柄,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,942評(píng)論 6 392
  • 文/花漫 我一把揭開白布文搂。 她就那樣靜靜地躺著适刀,像睡著了一般。 火紅的嫁衣襯著肌膚如雪煤蹭。 梳的紋絲不亂的頭發(fā)上笔喉,一...
    開封第一講書人閱讀 51,727評(píng)論 1 305
  • 那天取视,我揣著相機(jī)與錄音,去河邊找鬼常挚。 笑死作谭,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的奄毡。 我是一名探鬼主播丢早,決...
    沈念sama閱讀 40,447評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼秧倾!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起傀缩,我...
    開封第一講書人閱讀 39,349評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤那先,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后赡艰,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體售淡,經(jīng)...
    沈念sama閱讀 45,820評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,990評(píng)論 3 337
  • 正文 我和宋清朗相戀三年慷垮,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了揖闸。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,127評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡料身,死狀恐怖汤纸,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情芹血,我是刑警寧澤贮泞,帶...
    沈念sama閱讀 35,812評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站幔烛,受9級(jí)特大地震影響啃擦,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜饿悬,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,471評(píng)論 3 331
  • 文/蒙蒙 一令蛉、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧狡恬,春花似錦珠叔、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至函卒,卻和暖如春辆憔,著一層夾襖步出監(jiān)牢的瞬間撇眯,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評(píng)論 1 272
  • 我被黑心中介騙來泰國打工虱咧, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留熊榛,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,388評(píng)論 3 373
  • 正文 我出身青樓腕巡,卻偏偏與公主長得像玄坦,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子绘沉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,066評(píng)論 2 355

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