leetcode 33 搜索旋轉(zhuǎn)排序數(shù)組

leetcode 33 搜索旋轉(zhuǎn)排序數(shù)組

第一次題解

思路:將數(shù)組分為兩份星掰,左邊的數(shù)組可能是有序的可能是無(wú)須的叫倍,通過(guò)一個(gè)while找出[left, mid] 是有序的,這樣能找到旋轉(zhuǎn)位置解愤,再根據(jù)二分搜索法找出taget值冈绊。

自我點(diǎn)評(píng)

  1. 時(shí)間復(fù)雜度為log(n)級(jí)別
  2. 應(yīng)多用注釋標(biāo)記出邊界點(diǎn)范圍節(jié)省調(diào)試的時(shí)間侠鳄。
  3. 局限于找出旋轉(zhuǎn)位置
  4. 代碼較多,理解起來(lái)困難
  5. 以后使用low死宣,hight單詞代替 left伟恶,right。
class Solution {

    fun search(nums: IntArray, target: Int): Int {
        if (nums.isEmpty()) return -1

        return searchTag(nums, 0, nums.lastIndex, target)
    }

    private fun searchTag(nums: IntArray, left: Int, right: Int, target: Int): Int {
        var mRight = right
        var mid = (left + mRight) / 2 // 可優(yōu)化 (right - left) / 2 + left
        // [left, mRight] 有序毅该,查找Tga值
        if (nums[left] <= nums[mRight]) return binarySearch(nums, left, mRight, target)

        // 找出 [left, mid] 是有序的
        while (nums[mid] < nums[left]) {
            mRight = mid
            mid = (left + mRight) / 2 // 可優(yōu)化 (right - left) / 2 + left
        }

        // target 存在 [let, mid] 之間
        if (target >= nums[left] && target <= nums[mid]) return binarySearch(nums, left, mid, target)

        // [mid+1, right] 從新搜索
        return searchTag(nums, mid + 1, right, target)
    }

    private fun binarySearch(nums: IntArray, left: Int, right: Int, target: Int): Int {
        if (left > right) return -1
        val mid = (right - left) / 2 + left  // 可優(yōu)化 (right - left) / 2 + left

        return when {
            nums[mid] == target -> mid
            nums[mid] < target -> binarySearch(nums, mid + 1, right, target)
            else -> binarySearch(nums, left, mid - 1, target)
        }
    }


}

優(yōu)雅解法

思路:如果中間的數(shù)小于最右邊的數(shù)博秫,則右半段是有序的,若中間數(shù)大于最右邊數(shù)眶掌,則左半段是有序的挡育,我們只要在有序的半段里用首尾兩個(gè)數(shù)組來(lái)判斷目標(biāo)值是否在這一區(qū)域內(nèi),這樣就可以確定保留哪半邊了

class Solution {

    fun search(nums: IntArray, target: Int): Int {
        if (nums.isEmpty()) return -1

        return searchTag(nums, 0, nums.lastIndex, target)
    }

    private fun searchTag(nums: IntArray, left: Int, right: Int, target: Int): Int {
        var low = left
        var hight = right

        while (low <= hight) {
            val mid = (low + hight) / 2
            if (target == nums[mid]) return mid

            if (nums[mid] < nums[hight]) {// [mid, right]
                if (nums[mid]< target && target <= nums[hight]) low = mid + 1 // num[mid] < target <= num[right]
                else hight = mid - 1
            }else {
                if (nums[low] <= target && target < nums[mid]) hight = mid - 1 // num[right] <= target < num[mid]
                else low = mid + 1
            }
        }

        return -1
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末朴爬,一起剝皮案震驚了整個(gè)濱河市即寒,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌召噩,老刑警劉巖母赵,帶你破解...
    沈念sama閱讀 207,248評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異具滴,居然都是意外死亡凹嘲,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門构韵,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)施绎,“玉大人,你說(shuō)我怎么就攤上這事贞绳」茸恚” “怎么了?”我有些...
    開封第一講書人閱讀 153,443評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵冈闭,是天一觀的道長(zhǎng)俱尼。 經(jīng)常有香客問(wèn)我,道長(zhǎng)萎攒,這世上最難降的妖魔是什么遇八? 我笑而不...
    開封第一講書人閱讀 55,475評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮耍休,結(jié)果婚禮上刃永,老公的妹妹穿的比我還像新娘。我一直安慰自己羊精,他們只是感情好斯够,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,458評(píng)論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般读规。 火紅的嫁衣襯著肌膚如雪抓督。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,185評(píng)論 1 284
  • 那天束亏,我揣著相機(jī)與錄音铃在,去河邊找鬼。 笑死碍遍,一個(gè)胖子當(dāng)著我的面吹牛定铜,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播怕敬,決...
    沈念sama閱讀 38,451評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼宿稀,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了赖捌?” 一聲冷哼從身側(cè)響起祝沸,我...
    開封第一講書人閱讀 37,112評(píng)論 0 261
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤敛苇,失蹤者是張志新(化名)和其女友劉穎稽屏,沒(méi)想到半個(gè)月后睁本,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體暂衡,經(jīng)...
    沈念sama閱讀 43,609評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡句喜,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,083評(píng)論 2 325
  • 正文 我和宋清朗相戀三年厌杜,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了射窒。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片许昨。...
    茶點(diǎn)故事閱讀 38,163評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡桑驱,死狀恐怖竭恬,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情熬的,我是刑警寧澤痊硕,帶...
    沈念sama閱讀 33,803評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站押框,受9級(jí)特大地震影響岔绸,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜橡伞,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,357評(píng)論 3 307
  • 文/蒙蒙 一盒揉、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧兑徘,春花似錦刚盈、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)欲侮。三九已至,卻和暖如春谴分,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背镀脂。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工牺蹄, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人薄翅。 一個(gè)月前我還...
    沈念sama閱讀 45,636評(píng)論 2 355
  • 正文 我出身青樓沙兰,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親翘魄。 傳聞我的和親對(duì)象是個(gè)殘疾皇子鼎天,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,925評(píng)論 2 344

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