編程珠璣《Programming Pearls》---再不讀經(jīng)典就鞋材了

編程珠璣《Programming Pearls》---再不讀經(jīng)典就鞋材了

閱讀計(jì)劃

這本書的前言已經(jīng)叮囑了囊陡,對于這本書讀起來要
盡量的慢捆等,讀精讀頭才可以降铸。這也正好符合我懶的作風(fēng)住拭。
正好潭袱,[慢慢磨這本書宰睡,計(jì)劃在一個(gè)月內(nèi)讀完酿愧。]
因?yàn)槭窃趫D書館借的声邦,目前我有個(gè)計(jì)劃是在畢業(yè)之前
把圖書館的經(jīng)典書籍都看完挽牢,不論是技術(shù)類還是什么,
而且做好筆記彤悔,筆記不做也要做好書單的記錄嘉抓。
let us do IT! 不用點(diǎn)英語沒有逼格,下面這本書簡稱Pears晕窑,
具體原因是linux下的輸入法很難用抑片,珠璣很難打。

第一章

關(guān)于排序的反思

一直在學(xué)習(xí)排序杨赤,基本的排序比如二叉樹敞斋,堆截汪,歸并,塊排植捎,
大都了解衙解,但排序的哲學(xué)在于當(dāng)齊面對上G大小的數(shù)據(jù)時(shí)的性能如何,
對于我們初學(xué)者來說焰枢,我們重點(diǎn)方錯(cuò)了位置蚓峦,我們以為會(huì)用排序
排一個(gè)10個(gè)數(shù)字的數(shù)組就算完成了,其實(shí)更加需要注意的是如何在大數(shù)據(jù)的面前利用排序算法更加有效的進(jìn)行大數(shù)的排序济锄,所以1G的數(shù)據(jù)如何生成也是我們需要研究的暑椰。

如何生成1G的數(shù)據(jù)?

    1.隨機(jī)生成一個(gè)文件拟淮。
    2.在網(wǎng)上down一個(gè)二進(jìn)制文件

Pears的第一個(gè)問題描述

如何給磁盤文件排序干茉?

    輸入:一個(gè)最多包含n個(gè)正整數(shù)的文件谴忧,每個(gè)數(shù)都小于n很泊,
    其中n = 10^7。如果在輸入文件中有任何整數(shù)重復(fù)出現(xiàn)就是致命錯(cuò)誤沾谓。
    輸出:按排序排列的輸入整數(shù)的列表委造。
    約束:最多有(大約)1MB的內(nèi)存空間可用,有充足的磁盤存儲(chǔ)空間可用均驶。運(yùn)行時(shí)間最多
    幾分鐘昏兆,運(yùn)行時(shí)間為10s就不需要進(jìn)一步優(yōu)化了。

利用位圖排序

    書中提到了利用歸并去實(shí)現(xiàn)妇穴。
    但歸并的缺點(diǎn)在于需要輔助內(nèi)存的不斷讀出寫入爬虱,所以數(shù)據(jù)大了之后效率會(huì)下降。

可以采用位圖來做腾它。

代碼#include<回來寫跑筝,打球去了>
#include <iostream>     // std::cout
#include <algorithm>    // std::for_each
#include <vector>       // std::vector
using namespace std;

void fun(int i){
    cout << i << ' ';
}

int main(int argc, char const *argv[])
{
    //
    int i{};
    int bit[10];
    for(i = 0;i < 10;++i){
        bit[i] = 0;
    }
    bit[0] = 0;
    bit[2] = 1;
    bit[3] = 1;
    bit[4] = 1;
    bit[6] = 1;
    bit[7] = 1;

    // for_each(bit,bit+10,fun);
    for(i = 0;i < 10;++i){
        if(bit[i] == 1){
            cout << i << ' ';
        }
    }

    cout << endl;
    return 0;
}   

root@fangzhenhua-Lenovo-G510:/home/kevin/ProgrammingPearls# ./a.out
2 3 4 6 7

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市瞒滴,隨后出現(xiàn)的幾起案子曲梗,更是在濱河造成了極大的恐慌,老刑警劉巖妓忍,帶你破解...
    沈念sama閱讀 222,183評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件虏两,死亡現(xiàn)場離奇詭異,居然都是意外死亡世剖,警方通過查閱死者的電腦和手機(jī)定罢,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來旁瘫,“玉大人引颈,你說我怎么就攤上這事耕皮。” “怎么了蝙场?”我有些...
    開封第一講書人閱讀 168,766評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵凌停,是天一觀的道長。 經(jīng)常有香客問我售滤,道長罚拟,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,854評(píng)論 1 299
  • 正文 為了忘掉前任完箩,我火速辦了婚禮赐俗,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘弊知。我一直安慰自己阻逮,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,871評(píng)論 6 398
  • 文/花漫 我一把揭開白布秩彤。 她就那樣靜靜地躺著叔扼,像睡著了一般。 火紅的嫁衣襯著肌膚如雪漫雷。 梳的紋絲不亂的頭發(fā)上瓜富,一...
    開封第一講書人閱讀 52,457評(píng)論 1 311
  • 那天,我揣著相機(jī)與錄音降盹,去河邊找鬼与柑。 笑死,一個(gè)胖子當(dāng)著我的面吹牛蓄坏,可吹牛的內(nèi)容都是我干的价捧。 我是一名探鬼主播,決...
    沈念sama閱讀 40,999評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼涡戳,長吁一口氣:“原來是場噩夢啊……” “哼结蟋!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起妹蔽,我...
    開封第一講書人閱讀 39,914評(píng)論 0 277
  • 序言:老撾萬榮一對情侶失蹤椎眯,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后胳岂,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體编整,經(jīng)...
    沈念sama閱讀 46,465評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,543評(píng)論 3 342
  • 正文 我和宋清朗相戀三年乳丰,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了掌测。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,675評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡产园,死狀恐怖汞斧,靈堂內(nèi)的尸體忽然破棺而出夜郁,到底是詐尸還是另有隱情,我是刑警寧澤粘勒,帶...
    沈念sama閱讀 36,354評(píng)論 5 351
  • 正文 年R本政府宣布竞端,位于F島的核電站,受9級(jí)特大地震影響庙睡,放射性物質(zhì)發(fā)生泄漏事富。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,029評(píng)論 3 335
  • 文/蒙蒙 一乘陪、第九天 我趴在偏房一處隱蔽的房頂上張望统台。 院中可真熱鬧,春花似錦啡邑、人聲如沸贱勃。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,514評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽贵扰。三九已至,卻和暖如春森缠,著一層夾襖步出監(jiān)牢的瞬間拔鹰,已是汗流浹背仪缸。 一陣腳步聲響...
    開封第一講書人閱讀 33,616評(píng)論 1 274
  • 我被黑心中介騙來泰國打工贵涵, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人恰画。 一個(gè)月前我還...
    沈念sama閱讀 49,091評(píng)論 3 378
  • 正文 我出身青樓宾茂,卻偏偏與公主長得像,于是被迫代替她去往敵國和親拴还。 傳聞我的和親對象是個(gè)殘疾皇子跨晴,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,685評(píng)論 2 360

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

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,305評(píng)論 25 707
  • 本文把程序員所需掌握的關(guān)鍵知識(shí)總結(jié)為三大類19個(gè)關(guān)鍵概念,然后給出了掌握每個(gè)關(guān)鍵概念所需的入門書籍片林,必讀書籍端盆,以及...
    dle_oxio閱讀 11,139評(píng)論 6 244
  • 第一部分、十道海量數(shù)據(jù)處理面試題 1费封、海量日志數(shù)據(jù)焕妙,提取出某日訪問百度次數(shù)最多的那個(gè)IP。 此題弓摘,在我之前的一篇文...
    零一間閱讀 924評(píng)論 0 5
  • 摘要:本文將向您講述諸多數(shù)據(jù)處理面試題以及方法的總結(jié)焚鹊。 第一部分、十道海量數(shù)據(jù)處理面試題 1韧献、海量日志數(shù)據(jù)末患,提取出...
    拾壹北閱讀 1,698評(píng)論 0 28
  • 他的女朋友在商場試衣服試了很久研叫,他不時(shí)的站起來又坐下,來回走動(dòng)璧针,女朋友問他衣服怎么樣嚷炉,他敷衍的說 都挺好√匠鳎可以看出...
    嘰嘰咕咕lu閱讀 218評(píng)論 0 0