劍指offer 第一天

一些有用的廢話

遠(yuǎn)程寫(xiě)代碼注意點(diǎn)

  • 思考清楚再開(kāi)始編碼 腦子永遠(yuǎn)應(yīng)該在手前面 不止是面試藏鹊,任何事都是如此腺办。
  • 良好的代碼命名和縮進(jìn)習(xí)慣 我叫sunny怎么了那篇招聘一個(gè)靠譜的 iOS第一題就是風(fēng)格糾錯(cuò)題,大家可以去看看式曲。
  • 能夠單元測(cè)試

高質(zhì)量的代碼

  • 考慮邊界 錯(cuò)誤處理等

清晰的思路

  • 舉幾個(gè)簡(jiǎn)單的例子
  • 用圖形表示抽象的數(shù)據(jù)結(jié)構(gòu)
  • 把復(fù)雜問(wèn)題分解成若干子問(wèn)題

應(yīng)聘提問(wèn)環(huán)節(jié)推薦問(wèn)與招聘的職位或者項(xiàng)目相關(guān)的問(wèn)題

數(shù)據(jù)結(jié)構(gòu)

數(shù)組

數(shù)組根據(jù)下標(biāo)讀寫(xiě)的特點(diǎn)時(shí)間效率非常高场钉,可以用數(shù)組實(shí)現(xiàn)簡(jiǎn)單的哈希表来吩。

面試題 二維數(shù)組的查找

屏幕快照 2016-03-29 下午7.43.26.png

首先我們可以在紙上畫(huà)出一個(gè)二維數(shù)組,假設(shè)查找7戚长。當(dāng)我們從右上角開(kāi)始查找時(shí),無(wú)非就三種情況怠苔,
該元素等于7同廉,那么查找成功,打印出所在行列
該元素小于7迫肖,該行所有元素都小于7 該行不用找了
該元素大于7,該列所有元素都大于7 該列不用找了蟆湖。
思路理清以后 可以寫(xiě)代碼了
關(guān)鍵代碼如下

void Find(int cols,int rows){
if (cols>0&&rows>0) {
    int row=0;
    int col=cols-1;
    while (row <rows && col>=0) {
        //右上角元素
        if (a[row][col]==x) {
            printf("%d行%d列",row+1,col+1);
            //return;
        }else if (a[row][col]>x){
            col--;
        }else{
            row++;
        }
    }
}
return;
   }

從左下角也可以鸠天,代碼如下

void LeftFind(int cols,int rows){
if (cols>0&&rows>0){
int row=rows-1;
int col=0;
while (col<cols&&row>=0) {
    if (a[row][col]==x) {
        printf("%d行%d列",row+1,col+1);
        
    }else if (a[row][col]<x){
        col++;
    }else{
        row--;
    }
}
}
return;

}
本題的思考 當(dāng)遇到一個(gè)復(fù)雜問(wèn)題時(shí),不要急著編碼帐姻,可以通過(guò)畫(huà)圖用具體的例子尋找規(guī)律。

字符串

屏幕快照 2016-03-29 下午8.13.44.png

一種減少移動(dòng)次數(shù)的方法 先遍歷字符串統(tǒng)計(jì)出空格的總數(shù)饥瓷,算好擴(kuò)展后的字符串長(zhǎng)度痹籍,然后從后向前替換呢铆。
關(guān)鍵代碼如下

void ReplaceBlank(char string[]){
if (string==NULL) {
    return;
}
int index1=0;
int index2=0;
    int blankCount=0;
//遍歷字符串,讓index1指向最后一個(gè)字符 并統(tǒng)計(jì)空格數(shù)
while (string[index1]!='\0') {
   if (string[index1]==' ') {
        blankCount++;
    }
    index1++;
    
}

int newlength=index1+blankCount*2;
index2=newlength;
while (index1>=0&&index1<index2) {
    if (string[index1]==' ') {
        
        string[index2--]='0';
        string[index2--]='1';
        string[index2--]='%';
    }else{
        string[index2--]=string[index1];
        }
    index1--;
}
}

相關(guān)題目 兩個(gè)排序好的數(shù)組a b a有足夠空間容納b 寫(xiě)一個(gè)函數(shù)把b中所有數(shù)字插到a中
本題的思考 合并數(shù)組和字符串棺克,我們可以考慮通過(guò)從后向前復(fù)制減少移動(dòng)次數(shù)
代碼

void insert(){
int i=5;
int j=10;
for (int k=4; k>=0; k--) {
    //當(dāng)b元素小于a時(shí) 移動(dòng)a中元素
        while (b[k]<a[i]&&i>=0) {
            a[j]=a[i];
            j--;
            i--;
        }
    //b中元素大于等于a中的元素 插入a
        //如果a全部移到后面 那么不用比較 把b全部插入
        if (i==0) {
            while (k>=0) {
                a[j]=b[k];
                j--;
                k--;
                return;
            }
        }
        a[j]=b[k];
        j--;
     }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末线定,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子斤讥,更是在濱河造成了極大的恐慌,老刑警劉巖派草,帶你破解...
    沈念sama閱讀 212,718評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件铛楣,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡簸州,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,683評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)拓瞪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)助琐,“玉大人祭埂,你說(shuō)我怎么就攤上這事∩嘟纾” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 158,207評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵呻拌,是天一觀的道長(zhǎng)睦焕。 經(jīng)常有香客問(wèn)我藐握,道長(zhǎng)垃喊,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,755評(píng)論 1 284
  • 正文 為了忘掉前任本谜,我火速辦了婚禮,結(jié)果婚禮上溜在,老公的妹妹穿的比我還像新娘。我一直安慰自己他托,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,862評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布培遵。 她就那樣靜靜地躺著登刺,像睡著了一般。 火紅的嫁衣襯著肌膚如雪纸俭。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 50,050評(píng)論 1 291
  • 那天郎楼,我揣著相機(jī)與錄音窒悔,去河邊找鬼。 笑死简珠,一個(gè)胖子當(dāng)著我的面吹牛虹钮,可吹牛的內(nèi)容都是我干的膘融。 我是一名探鬼主播芙粱,決...
    沈念sama閱讀 39,136評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼春畔,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼岛都!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起臼疫,我...
    開(kāi)封第一講書(shū)人閱讀 37,882評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后哈打,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,330評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡湾盗,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,651評(píng)論 2 327
  • 正文 我和宋清朗相戀三年立轧,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片氛改。...
    茶點(diǎn)故事閱讀 38,789評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡胜卤,死狀恐怖疆导,靈堂內(nèi)的尸體忽然破棺而出葛躏,到底是詐尸還是另有隱情,我是刑警寧澤舰攒,帶...
    沈念sama閱讀 34,477評(píng)論 4 333
  • 正文 年R本政府宣布摩窃,位于F島的核電站兽叮,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏德玫。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,135評(píng)論 3 317
  • 文/蒙蒙 一宰僧、第九天 我趴在偏房一處隱蔽的房頂上張望观挎。 院中可真熱鬧,春花似錦嘁捷、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,864評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)鼓鲁。三九已至港谊,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間歧寺,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,099評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工龙致, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留顷链,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,598評(píng)論 2 362
  • 正文 我出身青樓蕴潦,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親忽冻。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,697評(píng)論 2 351

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

  • 數(shù)組在程序設(shè)計(jì)中僧诚,為了處理方便, 把具有相同類型的若干變量按有序的形式組織起來(lái)旗扑。這些按序排列的同類數(shù)據(jù)元素的集合稱...
    朱森閱讀 3,905評(píng)論 2 13
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語(yǔ)法慈省,類相關(guān)的語(yǔ)法臀防,內(nèi)部類的語(yǔ)法边败,繼承相關(guān)的語(yǔ)法,異常的語(yǔ)法笑窜,線程的語(yǔ)...
    子非魚(yú)_t_閱讀 31,602評(píng)論 18 399
  • 有些時(shí)候你才能認(rèn)識(shí)到現(xiàn)實(shí) 時(shí)間到了 吃了苦頭 自然就明白了 曾今追夢(mèng)的人 注定和現(xiàn)實(shí)有點(diǎn)脫軌
    精神麻雀閱讀 159評(píng)論 0 0
  • 九歲那年全家搬遷排截,我也轉(zhuǎn)到了新的地方讀書(shū)。 當(dāng)時(shí)萬(wàn)般不樂(lè)意断傲,但是現(xiàn)在回想起來(lái)卻十分慶幸。小學(xué)的最后一年時(shí)光艳悔,是我單...
    星星上的月亮閱讀 179評(píng)論 0 0
  • 原材料收集好之后女仰,也就是捕捉之后,必須明確其意義疾忍。 明確意義這個(gè)步驟只能靠你自己完成,如果你自己不會(huì)把你捕捉到的事...
    狒狒0810閱讀 129評(píng)論 0 0