劍指offer(一)

1.在一個(gè)二維數(shù)組中(每個(gè)一維數(shù)組的長度相同)癌蓖,每一行都按照從左到右遞增的順序排序,每一列都按照從上到下遞增的順序排序份名。請(qǐng)完成一個(gè)函數(shù)碟联,輸入這樣的一個(gè)二維數(shù)組和一個(gè)整數(shù)妓美,判斷數(shù)組中是否含有該整數(shù)。

方法一:普通方法鲤孵,全部遍歷一遍

public class Solution {

????public boolean Find(int target,?int[][] array)?

?????????????for(int i=0;i<array.length;i++){

?????????????????for(int j=0;j<array[0].length;j++){

?????????????????????if(target==array[i][j])

????????????????????????return true;

?????????????????}

?????????????}

?????????????return false;

????}

}

方法二:利用題目要求從左下角開始遍歷壶栋,若是比左下角數(shù)字大則在右邊查找,否則向上查找

public class Solution {

? ? public boolean Find(int target, int [][] array){

? ? ? ? int row = array.length-1;

? ? ? ? int col = 0;

? ? ? ? while(col<array[0].length&&row>=0){

? ? ? ? ? ? if(target==array[row][col]){

? ? ? ? ? ? ? ? return true;

? ? ? ? ? ? }

? ? ? ? ? ? else if(target>array[row][col]){

? ? ? ? ? ? ? ? col++;

? ? ? ? ? ? }

? ? ? ? ? ? else{

? ? ? ? ? ? ? ? row--;

? ? ? ? ? ? }

? ? ? ? }

? ? ? return false;

? ? }

}

方法三:二分查找

public class Solution {

? ? public boolean Find(int target, int [][] array){

? ? ? ? for(int i=0;i<array.length;i++){

? ? ? ? ? ? int left = 0;

? ? ? ? ? ? int right = array[i].length-1;

? ? ? ? ? ? while(left<=right){

? ? ? ? ? ? ? ? int flag = (left+right)/2;

? ? ? ? ? ? ? ? if(target>array[i][flag]){

? ? ? ? ? ? ? ? ? ? left=flag+1;

? ? ? ? ? ? ? ? }

? ? ? ? ? ? ? ? else if(target<array[i][flag])

? ? ? ? ? ? ? ? ? ? right=flag-1;

? ? ? ? ? ? ? ? else

? ? ? ? ? ? ? ? ? ? return true;

? ? ? ? ? ? }

? ? ? ? }

? ? ? ? return false;

? ? }

}

2.請(qǐng)實(shí)現(xiàn)一個(gè)函數(shù)普监,將一個(gè)字符串中的每個(gè)空格替換成“%20”贵试。例如,當(dāng)字符串為We Are Happy.則經(jīng)過替換之后的字符串為We%20Are%20Happy凯正。

方法一:將StringBuffer轉(zhuǎn)為String類型再使用replace方法

public class Solution {

? ? public String replaceSpace(StringBuffer str) {

? ? return str.toString().replaceAll("\\s","%20");

? ? }

}

方法二:遍歷加入到新的StringBuffer對(duì)象中

public class Solution {

? ? public String replaceSpace(StringBuffer str) {

? ? String s = str.toString();

? ? ? ? char[] s1 = s.toCharArray();

? ? ? ? StringBuffer s2 = new StringBuffer();

? ? ? ? for(int i=0;i<s1.length;i++){

? ? ? ? ? ? if(s1[i]==' '){

? ? ? ? ? ? ? ? s2.append("%20");

? ? ? ? ? ? }

? ? ? ? ? ? else{

? ? ? ? ? ? ? ? s2.append(s1[i]);

? ? ? ? ? ? }

? ? ? ? }

? ? ? ? return s2.toString();

? ? }

}

方法三:遍歷在原對(duì)象中操作

public class Solution {

? ? public String replaceSpace(StringBuffer str) {


? ? ? ? for(int i=0;i<str.length();i++){

? ? ? ? ? ? if(str.charAt(i)==' '){

? ? ? ? ? ? ? ? str.deleteCharAt(i);

? ? ? ? ? ? ? ? str.insert(i,"%20");

? ? ? ? ? ? }

? ? ? ? }

? ? ? ? return str.toString();

? ? }

}

3.輸入一個(gè)鏈表毙玻,按鏈表值從尾到頭的順序返回一個(gè)ArrayList。

方法一:利用遞歸將鏈表中的數(shù)據(jù)從尾到頭加入到新的鏈表

import java.util.ArrayList;

public class Solution {

? ? public ArrayList<Integer> printListFromTailToHead(ListNode listNode) {

? ? ? ? ArrayList arraylist = new ArrayList();

? ? ? ? if(listNode!=null){

? ? ? ? ? ? this.printListFromTailToHead(listNode.next);

? ? ? ? ? ? arraylist.add(listNode.val);

? ? ? ? }

? ? ? ? return arraylist;?

? ? }

}

方法二:

import java.util.ArrayList;

public class Solution {


? ? public ArrayList<Integer> printListFromTailToHead(ListNode listNode) {

? ? ? ? ArrayList<Integer> arraylist = new ArrayList<Integer>();

? ? ? ? ListNode pre=null;

? ? ? ? ListNode next=null;

? ? ? ? while(listNode!=null){

? ? ? ? ? ? next=listNode.next;

? ? ? ? ? ? listNode.next = pre;

? ? ? ? ? ? pre=listNode;

? ? ? ? ? ? listNode= next;

? ? ? ? }

? ? ? ? while(pre!=null){

? ? ? ? ? ? arraylist.add(pre.val);

? ? ? ? ? ? pre=pre.next;

? ? ? ? }

? ? ? ? return arraylist;

? ? }

}

4.大家都知道斐波那契數(shù)列廊散,現(xiàn)在要求輸入一個(gè)整數(shù)n淆珊,請(qǐng)你輸出斐波那契數(shù)列的第n項(xiàng)(從0開始,第0項(xiàng)為0)奸汇。

n<=39

方法一:遞歸

public class Solution {

? ? public int Fibonacci(int n) {

? ? ? ? if(n<=0) return 0;

? ? ? ? if(n==1||n==2)

? ? ? ? ? ? return 1;

? ? ? ? return Fibonacci(n-1)+Fibonacci(n-2);

? ? }

}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末施符,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子擂找,更是在濱河造成了極大的恐慌戳吝,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,744評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件贯涎,死亡現(xiàn)場離奇詭異听哭,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)塘雳,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,505評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門陆盘,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人败明,你說我怎么就攤上這事隘马。” “怎么了妻顶?”我有些...
    開封第一講書人閱讀 163,105評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵酸员,是天一觀的道長。 經(jīng)常有香客問我讳嘱,道長幔嗦,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,242評(píng)論 1 292
  • 正文 為了忘掉前任沥潭,我火速辦了婚禮邀泉,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己汇恤,他們只是感情好庞钢,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,269評(píng)論 6 389
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著屁置,像睡著了一般焊夸。 火紅的嫁衣襯著肌膚如雪仁连。 梳的紋絲不亂的頭發(fā)上蓝角,一...
    開封第一講書人閱讀 51,215評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音饭冬,去河邊找鬼使鹅。 笑死,一個(gè)胖子當(dāng)著我的面吹牛昌抠,可吹牛的內(nèi)容都是我干的患朱。 我是一名探鬼主播,決...
    沈念sama閱讀 40,096評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼炊苫,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼裁厅!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起侨艾,我...
    開封第一講書人閱讀 38,939評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤执虹,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后唠梨,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體袋励,經(jīng)...
    沈念sama閱讀 45,354評(píng)論 1 311
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,573評(píng)論 2 333
  • 正文 我和宋清朗相戀三年当叭,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了茬故。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,745評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡蚁鳖,死狀恐怖磺芭,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情醉箕,我是刑警寧澤徘跪,帶...
    沈念sama閱讀 35,448評(píng)論 5 344
  • 正文 年R本政府宣布,位于F島的核電站琅攘,受9級(jí)特大地震影響垮庐,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜坞琴,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,048評(píng)論 3 327
  • 文/蒙蒙 一哨查、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧剧辐,春花似錦寒亥、人聲如沸邮府。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,683評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽褂傀。三九已至,卻和暖如春加勤,著一層夾襖步出監(jiān)牢的瞬間仙辟,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,838評(píng)論 1 269
  • 我被黑心中介騙來泰國打工鳄梅, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留叠国,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,776評(píng)論 2 369
  • 正文 我出身青樓戴尸,卻偏偏與公主長得像粟焊,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子孙蒙,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,652評(píng)論 2 354

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