LeetCode 27. 移除元素(C語言)

27. 移除元素

Description


給你一個數組 nums 和一個值 val企垦,你需要 原地 移除所有數值等于 *val *的元素蚕愤,并返回移除后數組的新長度担锤。

不要使用額外的數組空間胰伍,你必須僅使用 O(1) 額外空間并 原地 修改輸入數組兵扬。

元素的順序可以改變。你不需要考慮數組中超出新長度后面的元素乞巧。

示例 1:
給定 nums = [3,2,2,3], val = 3,
函數應該返回新的長度 2, 并且 nums 中的前兩個元素均為 2涨椒。
你不需要考慮數組中超出新長度后面的元素。

示例 2:
給定 nums = [0,1,2,2,3,0,4,2], val = 2,
函數應該返回新的長度 5, 并且 nums 中的前五個元素為 0, 1, 3, 0, 4。
注意這五個元素可為任意順序蚕冬。
你不需要考慮數組中超出新長度后面的元素免猾。

Analyze


給定的函數如下:


  • @param nums 一個整數數組
  • @param numsSize 數組長度
  • @param val 要移除的元素
  • @return 移除后的數組長度

此題在題目中隱含了一個條件,不過在示例中體現了囤热,就是題中只是說返回刪除后的數組長度猎提,但實際上返回的長度 n 在原數組的前 n 項是不能出現目標元素的,即并不能僅僅返回一個長度旁蔼,還要把數組的內容修改成符合的值锨苏。
這題可以這么考慮,采用雙指針從頭開始遍歷數組棺聊,一旦發(fā)現要刪除的元素蚓炬,保留一個指針,另一個指針繼續(xù)向下遍歷躺屁,直到找到一個非目標元素肯夏,此時直接把前面保留的目標元素覆蓋,同時犀暑,兩個指針之間的元素也要一個一個全部由非目標值覆蓋驯击,直到有一個指針遍歷完數組∧涂鳎可以參考如下例子:

示例2中給定 nums = [0,1,2,2,3,0,4,2]徊都,val = 2,此時 prelast 同時指向 0广辰,0 不是目標元素暇矫,兩指針同時往右移動直到 2,此時 prelast 都指向 2 這個目標元素择吊,因此 last 留下李根,pre 繼續(xù)往前尋找可以覆蓋 2 的元素,pre 往右移動 1發(fā)現其指向的還是 2几睛,繼續(xù)往右移動 1房轿,此時指向3這個非目標元素,因此用 pre 指向的 3 覆蓋 last 指向的 2 所森,然后 prelast 同時右移囱持,這時 lastpre 之間的值都是可以舍棄的值了(因為他們之間要么是目標元素,要么是已經用來覆蓋目標元素了)焕济,這樣循環(huán)直到遍歷完全纷妆,最后數組會變成這樣:[0,1晴弃,3掩幢,0逊拍,4,0粒蜈,4,2] 旗国,此時返回 last 所指向的下標就可以了枯怖。

Realization


  • 判斷


如果 i 指向的不是目標元素就覆蓋 j 指向的元素(這里沒有判斷 j 指向的是不是目標元素,因為如果 j 指向的是目標元素就得覆蓋能曾,如果不是的話相當于 ij 都指向同一個值度硝,也就不存在覆蓋了)

  • 提交


Dictionary


雙指針或者說快慢指針這種方法在LeetCode中用的十分頻繁,因此掌握好雙指針的用法不僅可以提高解題效率寿冕,對代碼的效率也有很大的提高蕊程。

附源代碼


int removeElement(int* nums, int numsSize, int val){
    int i = 0, j = 0;
    for(i = 0; i < numsSize; i++)
    {
        if(nums[i] != val)
        {
            nums[j++] = nums[i];
        }
    }
    return j;
}
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市驼唱,隨后出現的幾起案子藻茂,更是在濱河造成了極大的恐慌,老刑警劉巖玫恳,帶你破解...
    沈念sama閱讀 222,464評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件辨赐,死亡現場離奇詭異,居然都是意外死亡京办,警方通過查閱死者的電腦和手機掀序,發(fā)現死者居然都...
    沈念sama閱讀 95,033評論 3 399
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來惭婿,“玉大人不恭,你說我怎么就攤上這事〔萍ⅲ” “怎么了换吧?”我有些...
    開封第一講書人閱讀 169,078評論 0 362
  • 文/不壞的土叔 我叫張陵,是天一觀的道長钥星。 經常有香客問我式散,道長,這世上最難降的妖魔是什么打颤? 我笑而不...
    開封第一講書人閱讀 59,979評論 1 299
  • 正文 為了忘掉前任暴拄,我火速辦了婚禮,結果婚禮上编饺,老公的妹妹穿的比我還像新娘乖篷。我一直安慰自己,他們只是感情好透且,可當我...
    茶點故事閱讀 69,001評論 6 398
  • 文/花漫 我一把揭開白布撕蔼。 她就那樣靜靜地躺著豁鲤,像睡著了一般。 火紅的嫁衣襯著肌膚如雪鲸沮。 梳的紋絲不亂的頭發(fā)上琳骡,一...
    開封第一講書人閱讀 52,584評論 1 312
  • 那天,我揣著相機與錄音讼溺,去河邊找鬼楣号。 笑死,一個胖子當著我的面吹牛怒坯,可吹牛的內容都是我干的炫狱。 我是一名探鬼主播,決...
    沈念sama閱讀 41,085評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼剔猿,長吁一口氣:“原來是場噩夢啊……” “哼视译!你這毒婦竟也來了?” 一聲冷哼從身側響起归敬,我...
    開封第一講書人閱讀 40,023評論 0 277
  • 序言:老撾萬榮一對情侶失蹤酷含,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后汪茧,有當地人在樹林里發(fā)現了一具尸體第美,經...
    沈念sama閱讀 46,555評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,626評論 3 342
  • 正文 我和宋清朗相戀三年陆爽,在試婚紗的時候發(fā)現自己被綠了什往。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,769評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡慌闭,死狀恐怖别威,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情驴剔,我是刑警寧澤省古,帶...
    沈念sama閱讀 36,439評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站丧失,受9級特大地震影響豺妓,放射性物質發(fā)生泄漏。R本人自食惡果不足惜布讹,卻給世界環(huán)境...
    茶點故事閱讀 42,115評論 3 335
  • 文/蒙蒙 一琳拭、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧描验,春花似錦白嘁、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,601評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽鲁沥。三九已至,卻和暖如春耕魄,著一層夾襖步出監(jiān)牢的瞬間画恰,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,702評論 1 274
  • 我被黑心中介騙來泰國打工吸奴, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留允扇,地道東北人。 一個月前我還...
    沈念sama閱讀 49,191評論 3 378
  • 正文 我出身青樓奄抽,卻偏偏與公主長得像蔼两,于是被迫代替她去往敵國和親甩鳄。 傳聞我的和親對象是個殘疾皇子逞度,可洞房花燭夜當晚...
    茶點故事閱讀 45,781評論 2 361

推薦閱讀更多精彩內容