代碼隨想錄算法訓(xùn)練營第一天 | 704.二分查找片任、35.搜索插入位置、27.移除元素

題目704.二分查找(兩個前提:1.有序數(shù)組颅夺;2.無重復(fù)元素)

示例1:
輸入: nums = [-1,0,3,5,9,12], target = 9     
輸出: 4       
解釋: 9 出現(xiàn)在 nums 中并且下標為 4   

關(guān)鍵點:
1. 區(qū)間搜索的時候要明確區(qū)間定義:左閉右閉[]還是左閉右開[)朋截?左開右閉比較少見。吧黄。
2. 邊界處理部服,left<right還是left<=right,right=middle還是right=middle-1
3. 循環(huán)中根據(jù)區(qū)間定義做邊界處理,就是循環(huán)不變量規(guī)則:在while循環(huán)中堅持一個區(qū)間拗慨,區(qū)間即不變量

# 左閉右閉廓八,合法區(qū)間的話left可能等于right
left = 0, right = numsize - 1, target
while(left <= right):
    middle = (left + right)/2
    if nums[middle] > target:
        right = middle - 1
    else if nums[middle] < target:
        left = middle + 1
    else
        return middle
return -1

# 左閉右開, 合法區(qū)間的話left要小于right
left = 0, right = numsize, target
while(left < right):
    middle = (left + right)/2
    if nums[middle] > target:
        right = middle
    else if nums[middle] < target:
        left = middle + 1
    else
        return middle
return -1
                               

題目35.搜索插入位置

class Solution:
    def searchInsert(self, nums: List[int], target: int) -> int:
        left, right = 0, len(nums)-1
        while left <= right:
            middle = (left + right) // 2
            if nums[middle] > target:
                right = middle - 1
            elif nums[middle] < target:
                left = middle + 1
            else:
                return middle
        return left #假如原數(shù)組沒有該target赵抢,left位置為要插入的位置

題目27.移除元素

1. 限制O(1)的空間復(fù)雜度
2. 

## 暴力解法

class Solution:
    def removeElement(self, nums: List[int], val: int) -> int:
        i, j = 0, len(nums)
        while i < j:
            if nums[i] == val:
                for k in range(i+1, j): #range右邊是開區(qū)間剧蹂,因此取不到,所以j=len(nums)而不是len(nums)-1
                    nums[k-1] = nums[k]
                i -= 1 #因為元素被刪掉之后烦却,還要從當前位置開始查找宠叼,因此這里-1
                j -= 1
            i += 1
        return j

## 雙指針法
1. 用雙指針代替一層for循環(huán),相比于暴力解法的O(n^2)的時間復(fù)雜度短绸,雙指針可降低到O(n)的時間復(fù)雜度
2. 快指針用來尋找新數(shù)組所需要的元素
3. 慢指針用來定位要更新的位置


slow = fast = 0
for i in range(0, len(nums)):
    if nums[i] != val:
        nums[slow] = nums[fast]
        slow += 1
return slow

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末车吹,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子醋闭,更是在濱河造成了極大的恐慌窄驹,老刑警劉巖,帶你破解...
    沈念sama閱讀 223,126評論 6 520
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件证逻,死亡現(xiàn)場離奇詭異乐埠,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,421評論 3 400
  • 文/潘曉璐 我一進店門丈咐,熙熙樓的掌柜王于貴愁眉苦臉地迎上來瑞眼,“玉大人,你說我怎么就攤上這事棵逊∩烁恚” “怎么了?”我有些...
    開封第一講書人閱讀 169,941評論 0 366
  • 文/不壞的土叔 我叫張陵辆影,是天一觀的道長徒像。 經(jīng)常有香客問我,道長蛙讥,這世上最難降的妖魔是什么锯蛀? 我笑而不...
    開封第一講書人閱讀 60,294評論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮次慢,結(jié)果婚禮上旁涤,老公的妹妹穿的比我還像新娘。我一直安慰自己迫像,他們只是感情好劈愚,可當我...
    茶點故事閱讀 69,295評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著侵蒙,像睡著了一般造虎。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上纷闺,一...
    開封第一講書人閱讀 52,874評論 1 314
  • 那天,我揣著相機與錄音份蝴,去河邊找鬼犁功。 笑死,一個胖子當著我的面吹牛婚夫,可吹牛的內(nèi)容都是我干的浸卦。 我是一名探鬼主播,決...
    沈念sama閱讀 41,285評論 3 424
  • 文/蒼蘭香墨 我猛地睜開眼案糙,長吁一口氣:“原來是場噩夢啊……” “哼限嫌!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起时捌,我...
    開封第一講書人閱讀 40,249評論 0 277
  • 序言:老撾萬榮一對情侶失蹤怒医,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后奢讨,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體稚叹,經(jīng)...
    沈念sama閱讀 46,760評論 1 321
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,840評論 3 343
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了扒袖。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片塞茅。...
    茶點故事閱讀 40,973評論 1 354
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖季率,靈堂內(nèi)的尸體忽然破棺而出野瘦,到底是詐尸還是另有隱情,我是刑警寧澤飒泻,帶...
    沈念sama閱讀 36,631評論 5 351
  • 正文 年R本政府宣布缅刽,位于F島的核電站,受9級特大地震影響蠢络,放射性物質(zhì)發(fā)生泄漏衰猛。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 42,315評論 3 336
  • 文/蒙蒙 一刹孔、第九天 我趴在偏房一處隱蔽的房頂上張望啡省。 院中可真熱鬧,春花似錦髓霞、人聲如沸卦睹。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,797評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽结序。三九已至,卻和暖如春纵潦,著一層夾襖步出監(jiān)牢的瞬間徐鹤,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,926評論 1 275
  • 我被黑心中介騙來泰國打工邀层, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留返敬,地道東北人。 一個月前我還...
    沈念sama閱讀 49,431評論 3 379
  • 正文 我出身青樓寥院,卻偏偏與公主長得像劲赠,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子秸谢,可洞房花燭夜當晚...
    茶點故事閱讀 45,982評論 2 361

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