劍指offer1-2—Java版

1.二維數(shù)組中的查找

1.1題目描述:

??在一個二維數(shù)組中(每個一維數(shù)組的長度相同)筑辨,每一行都按照從左到右遞增的順序排序,每一列都按照從上到下遞增的順序排序。請完成一個函數(shù),輸入這樣的一個二維數(shù)組和一個整數(shù)簿训,判斷數(shù)組中是否含有該整數(shù)。

1.2思路介紹:

??要求時間復雜度 O(M + N),空間復雜度 O(1)强品。
??該二維數(shù)組中的一個數(shù)膘侮,小于它的數(shù)一定在其左邊携栋,大于它的數(shù)一定在其下邊竿开。因此努酸,從右上角開始查找像屋,就可以根據(jù) target 和當前元素的大小關(guān)系來縮小查找區(qū)間,當前元素的查找區(qū)間為左下角的所有元素麻献。

1.3代碼展示:

public class Solution {
    public boolean Find(int target, int [][] array) {
      //注意進行判空
          if(array.length==0 || array[0].length==0 || array==null)
              return false;
        int col=array[0].length,row=array.length;
        int c=col-1,r=0;
        while(c>=0 && r<row){
            if(target==array[r][c])
                return true;
            else if(target>array[r][c])
                r++;
            else c--;
        }
        return false;
 }
}

2.替換空格

2.1題目描述:

??請實現(xiàn)一個函數(shù)曙博,將一個字符串中的每個空格替換成“%20”畔塔。例如晓淀,當字符串為We Are Happy.則經(jīng)過替換之后的字符串為We%20Are%20Happy所袁。

2.2思路介紹:

??在當前字符串上進行替換。
????1.先計算替換后的字符串需要多大的空間凶掰,并對原字符串空間進行擴容燥爷;
????2.從后往前替換字符串的話,每個字符串只需要移動一次懦窘;
????3.如果從前往后局劲,每個字符串需要多次移動,效率較低奶赠。

2.3代碼展示:

public class Solution {
    public String replaceSpace(StringBuffer str) {
        //進行判空
        if(str.length()<=0 || str==null)
            return new String();
        int count=0;
       //計算空格的數(shù)量
        for(int i=0;i<str.length();i++){
            if(str.charAt(i)==' ')
                count++;
        }
        int oldIndex=str.length()-1;
       //計算擴容后的空間大小
        int newLength=str.length()+count*2;
        int newIndex=newLength-1;
        str.setLength(newLength);
        for(;oldIndex>=0 && oldIndex<newLength;oldIndex--){
            if(str.charAt(oldIndex)==' '){
                str.setCharAt(newIndex--,'0');
                str.setCharAt(newIndex--,'2');
                str.setCharAt(newIndex--,'%');
            }else
                //注意這里仍然是需要減減的
                str.setCharAt(newIndex--,str.charAt(oldIndex));
        }
        return str.toString();
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市药有,隨后出現(xiàn)的幾起案子毅戈,更是在濱河造成了極大的恐慌,老刑警劉巖愤惰,帶你破解...
    沈念sama閱讀 206,723評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件苇经,死亡現(xiàn)場離奇詭異,居然都是意外死亡宦言,警方通過查閱死者的電腦和手機扇单,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來奠旺,“玉大人蜘澜,你說我怎么就攤上這事∠炀危” “怎么了鄙信?”我有些...
    開封第一講書人閱讀 152,998評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長忿晕。 經(jīng)常有香客問我装诡,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,323評論 1 279
  • 正文 為了忘掉前任鸦采,我火速辦了婚禮宾巍,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘渔伯。我一直安慰自己顶霞,他們只是感情好,可當我...
    茶點故事閱讀 64,355評論 5 374
  • 文/花漫 我一把揭開白布咱旱。 她就那樣靜靜地躺著确丢,像睡著了一般。 火紅的嫁衣襯著肌膚如雪吐限。 梳的紋絲不亂的頭發(fā)上鲜侥,一...
    開封第一講書人閱讀 49,079評論 1 285
  • 那天,我揣著相機與錄音诸典,去河邊找鬼描函。 笑死,一個胖子當著我的面吹牛狐粱,可吹牛的內(nèi)容都是我干的舀寓。 我是一名探鬼主播,決...
    沈念sama閱讀 38,389評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼肌蜻,長吁一口氣:“原來是場噩夢啊……” “哼互墓!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起蒋搜,我...
    開封第一講書人閱讀 37,019評論 0 259
  • 序言:老撾萬榮一對情侶失蹤篡撵,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后豆挽,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體育谬,經(jīng)...
    沈念sama閱讀 43,519評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,971評論 2 325
  • 正文 我和宋清朗相戀三年帮哈,在試婚紗的時候發(fā)現(xiàn)自己被綠了膛檀。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,100評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡娘侍,死狀恐怖咖刃,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情憾筏,我是刑警寧澤僵缺,帶...
    沈念sama閱讀 33,738評論 4 324
  • 正文 年R本政府宣布,位于F島的核電站踩叭,受9級特大地震影響磕潮,放射性物質(zhì)發(fā)生泄漏翠胰。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,293評論 3 307
  • 文/蒙蒙 一自脯、第九天 我趴在偏房一處隱蔽的房頂上張望之景。 院中可真熱鬧,春花似錦膏潮、人聲如沸锻狗。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,289評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽轻纪。三九已至,卻和暖如春叠纷,著一層夾襖步出監(jiān)牢的瞬間刻帚,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,517評論 1 262
  • 我被黑心中介騙來泰國打工涩嚣, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留崇众,地道東北人。 一個月前我還...
    沈念sama閱讀 45,547評論 2 354
  • 正文 我出身青樓航厚,卻偏偏與公主長得像顷歌,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子幔睬,可洞房花燭夜當晚...
    茶點故事閱讀 42,834評論 2 345