Leetcode - Search in Rotated Sorted Array II

Paste_Image.png

My code:

public class Solution {
    public boolean search(int[] nums, int target) {
        if (nums == null || nums.length == 0)
            return false;
        return search(0, nums.length - 1, nums, target);
    }
    
    private boolean search(int begin, int end, int[] nums, int target) {
        if (begin > end)
            return false;
        else {
            int mid = (begin + end) / 2;
            if (nums[mid] > nums[end]) { // left is sorted
                if (nums[mid] < target) {
                    int i = mid + 1;
                    while (i <= end && nums[i] == nums[i - 1])
                        i++;
                    if (i >= nums.length)
                        return false;
                    else
                        return search(i, end, nums, target);
                }
                else if (nums[mid] > target) {
                    if (nums[begin] > target) { // in the right
                        int i = mid + 1;
                        while (i <= end && nums[i] == nums[i - 1])
                            i++;
                        if (i >= nums.length)
                            return false;
                        else
                            return search(i, end, nums, target);
                    }
                    else if (nums[begin] == target)
                        return true;
                    else { // in the left
                        int i = mid - 1;
                        while (i >= begin && nums[i] == nums[i + 1])
                            i--;
                        if (i < 0)
                            return false;
                        else
                            return search(begin + 1, i, nums, target);
                    }
                }
                else
                    return true;
            }
            else if (nums[mid] < nums[end]) { // right is sorted
                if (nums[mid] > target) {
                    int i = mid - 1;
                    while (i >= begin && nums[i] == nums[i + 1])
                        i--;
                    if (i < 0)
                        return false;
                    else
                        return search(begin, i, nums, target);
                }
                else if (nums[mid] < target) {
                    if (target < nums[end]) {
                        int i = mid + 1;
                        while (i <= end && nums[i] == nums[i - 1])
                            i++;
                        if (i >= nums.length)
                            return false;
                        else
                            return search(i, end, nums, target);
                    }
                    else if (target > nums[end]) {
                        int i = mid - 1;
                        while (i >= begin && nums[i] == nums[i + 1])
                            i--;
                        if (i < 0)
                            return false;
                        else
                            return search(begin, i, nums, target);
                    }
                    else
                        return true;    
                }   
                else
                    return true;
            }
            else
                if (nums[mid] == target)
                    return true;
                else
                    return search(begin, end - 1, nums, target);
        }
    }
}

My test result:

這道題目還是和前面的差不多光羞。然后就是要用while循環(huán)把重復(fù)的數(shù)字跳到。
然后就是同樣的注意點四瘫,當nums[mid] = nums[end] 時捶索,可能出現(xiàn)兩種情況八孝,右側(cè)已經(jīng)排序好或者左側(cè)已經(jīng)排序好董朝。所以不能確定。
于是干跛,就直接將end - 1子姜,重新進行搜索。
所以楼入,如果數(shù)組數(shù)字都是一樣的哥捕,需要進行 O(n)復(fù)雜度,而不再是之前的binary search 的 O(log n)

**
總結(jié): Array嘉熊, binary search
**

Anyway, Good luck, Richardo!

My code:

public class Solution {
    public boolean search(int[] nums, int target) {
        if (nums == null || nums.length == 0)
            return false;
        int begin = 0;
        int end = nums.length - 1;
        while (begin <= end) {
            int middle = (begin + end) / 2;
            if (nums[middle] < nums[end]) { // right part is sorted
                if (target < nums[middle]) {
                    end = middle - 1;
                }
                else if (target == nums[middle]) {
                    return true;
                }
                else if (target <= nums[end]) {
                    begin = middle + 1;
                }
                else {
                    end = middle - 1;
                }
            }
            else if (nums[middle] > nums[end]) { // left part is sorted
                if (target > nums[middle]) {
                    begin = middle + 1;
                }
                else if (target == nums[middle]) {
                    return true;
                }
                else if (target >= nums[0]) {
                    end = middle - 1;
                }
                else {
                    begin = middle + 1;
                }
            }
            else {
                if (target == nums[middle])
                    return true;
                else
                    end = end - 1;
            }
        }
        return false;
    }
}

差不多的題目遥赚。就把之前的情況細分。
nums[middle] < nums[end]
nums[middle] > nums[end]
nums[middle] == nums[end] -> end - 1
差不多阐肤。然后因為出現(xiàn)了重復(fù)元素所以可以滑動凫佛,用while循環(huán)加速讲坎。
但是我懶得寫了。第一次的版本是寫了的愧薛。

Anyway, Good luck, Richardo!

提供一種新的思路就是直接traverse晨炕, 復(fù)雜度是 O(n)
上面的做法, time complexity: best: O(log n), worst: O(n)

Anyway, Good luck, Richardo! -- 08/12/2016

My code:

public class Solution {
    public boolean search(int[] nums, int target) {
        if (nums == null || nums.length == 0) {
            return false;
        }
        
        int begin = 0;
        int end = nums.length - 1;
        while (begin <= end) {
            int mid = begin + (end - begin) / 2;
            if (target == nums[mid]) {
                return true;
            }
            else if (nums[begin] < nums[mid]) { // left is sorted
                if (nums[begin] <= target && target < nums[mid]) {
                    end = mid - 1;
                }
                else {
                    begin = mid + 1;
                }
            }
            else if (nums[begin] > nums[mid]) { // right is sorted
                if (nums[mid] < target && target <= nums[end]) {
                    begin = mid + 1;
                }
                else {
                    end = mid - 1;
                }
            }
            else {
                begin++;
            }
        }
        return false;
    }
}

reference:
https://discuss.leetcode.com/topic/310/when-there-are-duplicates-the-worst-case-is-o-n-could-we-do-better/3

much simpler code

首先判斷毫炉,左右那個部分是 sorted 瓮栗,然后再進行下一步。

Anyway, Good luck, Richardo! -- 09/21/2016

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末瞄勾,一起剝皮案震驚了整個濱河市遵馆,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌丰榴,老刑警劉巖,帶你破解...
    沈念sama閱讀 210,914評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件秆撮,死亡現(xiàn)場離奇詭異四濒,居然都是意外死亡,警方通過查閱死者的電腦和手機职辨,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,935評論 2 383
  • 文/潘曉璐 我一進店門盗蟆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人舒裤,你說我怎么就攤上這事喳资。” “怎么了腾供?”我有些...
    開封第一講書人閱讀 156,531評論 0 345
  • 文/不壞的土叔 我叫張陵仆邓,是天一觀的道長。 經(jīng)常有香客問我伴鳖,道長节值,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,309評論 1 282
  • 正文 為了忘掉前任榜聂,我火速辦了婚禮搞疗,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘须肆。我一直安慰自己匿乃,他們只是感情好,可當我...
    茶點故事閱讀 65,381評論 5 384
  • 文/花漫 我一把揭開白布豌汇。 她就那樣靜靜地躺著幢炸,像睡著了一般。 火紅的嫁衣襯著肌膚如雪拒贱。 梳的紋絲不亂的頭發(fā)上阳懂,一...
    開封第一講書人閱讀 49,730評論 1 289
  • 那天,我揣著相機與錄音,去河邊找鬼岩调。 笑死巷燥,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的号枕。 我是一名探鬼主播缰揪,決...
    沈念sama閱讀 38,882評論 3 404
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼葱淳!你這毒婦竟也來了钝腺?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,643評論 0 266
  • 序言:老撾萬榮一對情侶失蹤赞厕,失蹤者是張志新(化名)和其女友劉穎艳狐,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體皿桑,經(jīng)...
    沈念sama閱讀 44,095評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡毫目,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,448評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了诲侮。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片镀虐。...
    茶點故事閱讀 38,566評論 1 339
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖沟绪,靈堂內(nèi)的尸體忽然破棺而出刮便,到底是詐尸還是另有隱情,我是刑警寧澤绽慈,帶...
    沈念sama閱讀 34,253評論 4 328
  • 正文 年R本政府宣布恨旱,位于F島的核電站,受9級特大地震影響坝疼,放射性物質(zhì)發(fā)生泄漏窖杀。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,829評論 3 312
  • 文/蒙蒙 一裙士、第九天 我趴在偏房一處隱蔽的房頂上張望入客。 院中可真熱鬧,春花似錦腿椎、人聲如沸桌硫。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,715評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽铆隘。三九已至,卻和暖如春南用,著一層夾襖步出監(jiān)牢的瞬間膀钠,已是汗流浹背掏湾。 一陣腳步聲響...
    開封第一講書人閱讀 31,945評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留肿嘲,地道東北人融击。 一個月前我還...
    沈念sama閱讀 46,248評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像雳窟,于是被迫代替她去往敵國和親尊浪。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,440評論 2 348

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