【D27】單詞搜索&尋找旋轉(zhuǎn)排序數(shù)組中的最小值(LC 79&153)

79. 單詞搜索

題目描述

給定一個(gè)二維網(wǎng)格和一個(gè)單詞镰惦,找出該單詞是否存在于網(wǎng)格中栗精。
單詞必須按照字母順序十厢,通過(guò)相鄰的單元格內(nèi)的字母構(gòu)成,其中“相鄰”單元格是那些水平相鄰或垂直相鄰的單元格枝缔。同一個(gè)單元格內(nèi)的字母不允許被重復(fù)使用。

解題思路

深度優(yōu)先遍歷 + 回溯。

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

class Solution {
    char[] target;

    public boolean exist(char[][] board, String word) {
        if(word.length() == 0){
            return false;
        }
        target = word.toCharArray();

        //遍歷矩陣行列
        int rows = board.length, cols = board[0].length;
        for(int i = 0; i < rows; i++){
            for(int j = 0; j < cols; j++){
                if(check(board, i, j, 0)){
                    return true;
                } 
            }
        }
        return false;
    }

    //判斷從board[i][j]出發(fā)是否存在路徑word.subString(index, length - 1)
    public boolean check(char[][] board, int i, int j, int index){
        if(index >= target.length){
            //已找完全部
            return true;
        }

        if(outOfBound(board, i, j) || board[i][j] != target[index]){
            return false;
        }
        
        //防止重復(fù)查找
        board[i][j] = '0';

        if(check(board, i + 1, j, index + 1) || check(board, i - 1, j, index + 1)
        || check(board, i, j + 1, index + 1) || check(board, i, j - 1, index + 1)){
            return true;
        }

       //還原數(shù)組元素(撤銷選擇)
        board[i][j] = target[index];

        return false;
    }

    //判斷數(shù)組下標(biāo)是否越界
    public boolean outOfBound(char[][] board, int i, int j){
        if(i < 0 || i >= board.length || j < 0 || j >=board[0].length){
            return true;
        }
        return false;
    }

}

153. 尋找旋轉(zhuǎn)排序數(shù)組中的最小值

問(wèn)題描述

假設(shè)按照升序排序的數(shù)組在預(yù)先未知的某個(gè)點(diǎn)上進(jìn)行了旋轉(zhuǎn)骤素。例如,數(shù)組 [0,1,2,4,5,6,7] 可能變?yōu)?[4,5,6,7,0,1,2] 愚屁。
請(qǐng)找出其中最小的元素济竹。

  • 1 <= nums.length <= 5000
  • -5000 <= nums[i] <= 5000
  • nums 中的所有整數(shù)都是 唯一 的
  • nums 原來(lái)是一個(gè)升序排序的數(shù)組,但在預(yù)先未知的某個(gè)點(diǎn)上進(jìn)行了旋轉(zhuǎn)

解題思路1-暴力法

從頭到尾遍歷數(shù)組霎槐,找到最小值送浊。

代碼實(shí)現(xiàn)1-暴力法

class Solution {
    public int findMin(int[] nums) {
        int min = nums[0];
        for(int i = 1; i < nums.length; i++){
            if(nums[i] < min){
                min = nums[i];
            }
        }
        return min;
    }
}
  • 時(shí)間復(fù)雜度O(n),n為數(shù)組中的元素

解題思路2-二分查找

使用左閉右開(kāi)區(qū)間丘跌,保證最小值始終在這里面袭景。

代碼實(shí)現(xiàn)2-二分查找

class Solution {
    public int findMin(int[] nums) {
        int left = 0, right = nums.length - 1;
        if(nums[left] < nums[right]){
            //數(shù)組未被旋轉(zhuǎn),直接返回最小值
            return nums[left];
        }

        while(left < right){
            int mid = left + (right - left) / 2;
            if(nums[right] < nums[mid]){
                left = mid + 1;
            }else{
                right = mid;
            } 
        }

        return nums[left];
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末闭树,一起剝皮案震驚了整個(gè)濱河市耸棒,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌报辱,老刑警劉巖与殃,帶你破解...
    沈念sama閱讀 218,858評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡奈籽,警方通過(guò)查閱死者的電腦和手機(jī)饥侵,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)衣屏,“玉大人躏升,你說(shuō)我怎么就攤上這事±浅溃” “怎么了膨疏?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,282評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)钻弄。 經(jīng)常有香客問(wèn)我佃却,道長(zhǎng),這世上最難降的妖魔是什么窘俺? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,842評(píng)論 1 295
  • 正文 為了忘掉前任饲帅,我火速辦了婚禮,結(jié)果婚禮上瘤泪,老公的妹妹穿的比我還像新娘灶泵。我一直安慰自己,他們只是感情好对途,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,857評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布赦邻。 她就那樣靜靜地躺著,像睡著了一般实檀。 火紅的嫁衣襯著肌膚如雪惶洲。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,679評(píng)論 1 305
  • 那天膳犹,我揣著相機(jī)與錄音恬吕,去河邊找鬼。 笑死镣奋,一個(gè)胖子當(dāng)著我的面吹牛币呵,可吹牛的內(nèi)容都是我干的怀愧。 我是一名探鬼主播侨颈,決...
    沈念sama閱讀 40,406評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼芯义!你這毒婦竟也來(lái)了哈垢?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,311評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤扛拨,失蹤者是張志新(化名)和其女友劉穎耘分,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,767評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡求泰,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年央渣,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片渴频。...
    茶點(diǎn)故事閱讀 40,090評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡芽丹,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出卜朗,到底是詐尸還是另有隱情拔第,我是刑警寧澤,帶...
    沈念sama閱讀 35,785評(píng)論 5 346
  • 正文 年R本政府宣布场钉,位于F島的核電站蚊俺,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏逛万。R本人自食惡果不足惜泳猬,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,420評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望宇植。 院中可真熱鬧暂殖,春花似錦、人聲如沸当纱。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,988評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)坡氯。三九已至晨横,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間箫柳,已是汗流浹背手形。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,101評(píng)論 1 271
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留悯恍,地道東北人库糠。 一個(gè)月前我還...
    沈念sama閱讀 48,298評(píng)論 3 372
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像涮毫,于是被迫代替她去往敵國(guó)和親瞬欧。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,033評(píng)論 2 355

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