2018-06-13 機(jī)試準(zhǔn)備03

Hash值的應(yīng)用

將存儲(chǔ)位置與數(shù)據(jù)本身對于起來的存儲(chǔ)手段


一鸵隧、例2.5 統(tǒng)計(jì)同成績學(xué)生人數(shù)

在已知該例可以用Hash的前提下 實(shí)現(xiàn)還是很簡單的 只怕實(shí)際做題時(shí)想不到該方法绸罗。。

需要注意的是:

初始化總是忘記要比用例數(shù)量多+1 如0~100的整數(shù)應(yīng)該是Hash[101]?

并且數(shù)組初始化為0是Hash[101]={0} 不是直接=0


二豆瘫、例2.6 Sort (按從小到大輸出前m大的數(shù))

條件:待排序的數(shù)字?jǐn)?shù)量為1,000,000; 數(shù)據(jù)范圍為[-500,000,500,000]且各不相同;時(shí)間限制1s

分析:即使是快排珊蟀,復(fù)雜度O(nlogn),也會(huì)達(dá)到千萬級外驱,超過1s系洛;

? ? ? ? ? 數(shù)據(jù)范圍有限俊性,考慮Hash,利用一個(gè)數(shù)組分別統(tǒng)計(jì)每一種數(shù)字是否出現(xiàn)描扯。

心得:這道題一開始真的沒想到怎么用Hash定页,但是一看到上面這句話就想通了(可怕!

? ? ? ? ? ?接下來再從尾到頭遍歷數(shù)組绽诚,時(shí)間復(fù)雜度在1,000,000百萬級

代碼出現(xiàn)的問題:

1)最開始定義a[1000001]={0}這個(gè)數(shù)字時(shí)典徊,放在了main函數(shù)里,導(dǎo)致運(yùn)行時(shí)棧溢出恩够。也就是說大數(shù)組應(yīng)該定義在main函數(shù)外卒落。

原因分析:

數(shù)組定義在函數(shù)中時(shí),占用的內(nèi)存來自椃渫埃空間儡毕,棧空間是在進(jìn)程創(chuàng)建時(shí)初始化的扑媚,有固定的大小腰湾,一般為幾十KB,所以太大的數(shù)組會(huì)耗光椊桑空間费坊。而全局變量是在編譯的時(shí)候編到數(shù)據(jù)段的,可以比較大旬痹。

全局變量在靜態(tài)存儲(chǔ)區(qū)分配內(nèi)存附井,局部變量是在棧上分配內(nèi)存空間的。(c語言程序在運(yùn)行時(shí)會(huì)動(dòng)態(tài)創(chuàng)建一個(gè)堆棧段两残,里面存放著調(diào)用棧永毅,保存著函數(shù)的調(diào)用關(guān)系和局部變量。)如果數(shù)組太大人弓,可能會(huì)造成棧溢出卷雕。

所以對于大數(shù)組的定義,要么定義為全局變量票从,要么動(dòng)態(tài)分配內(nèi)存(malloc()來開辟堆空間漫雕,堆空間中的內(nèi)存是按需分配,自由增長的峰鄙,可以非常大浸间,32位的系統(tǒng)中可以大到4GB。)

2)該大數(shù)組雖然需要在外部定義吟榴,但是也需要在內(nèi)部初始化魁蒜,以免多組數(shù)據(jù)中用到已經(jīng)賦值的數(shù)組,影響結(jié)果。

3)輸出樣例中兜看,每個(gè)數(shù)字間隔了一個(gè)空格锥咸,但最后一個(gè)數(shù)字后無空格,所以應(yīng)該控制好空格的輸出

其他可改善的地方:

參考代碼中用到了OFFSET, 更有可讀性? #define OFFSET 500000

考慮題目中指明了數(shù)據(jù)“各不相同” 所以另外實(shí)現(xiàn)了數(shù)據(jù)相同時(shí)的Hash方法细移。其中主要的問題是空格的控制比較不熟練搏予。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市弧轧,隨后出現(xiàn)的幾起案子雪侥,更是在濱河造成了極大的恐慌,老刑警劉巖精绎,帶你破解...
    沈念sama閱讀 218,036評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件速缨,死亡現(xiàn)場離奇詭異,居然都是意外死亡代乃,警方通過查閱死者的電腦和手機(jī)旬牲,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,046評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來搁吓,“玉大人原茅,你說我怎么就攤上這事∏嬖。” “怎么了员咽?”我有些...
    開封第一講書人閱讀 164,411評論 0 354
  • 文/不壞的土叔 我叫張陵毒涧,是天一觀的道長贮预。 經(jīng)常有香客問我,道長契讲,這世上最難降的妖魔是什么仿吞? 我笑而不...
    開封第一講書人閱讀 58,622評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮捡偏,結(jié)果婚禮上唤冈,老公的妹妹穿的比我還像新娘。我一直安慰自己银伟,他們只是感情好你虹,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,661評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著彤避,像睡著了一般傅物。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上琉预,一...
    開封第一講書人閱讀 51,521評論 1 304
  • 那天董饰,我揣著相機(jī)與錄音,去河邊找鬼。 笑死卒暂,一個(gè)胖子當(dāng)著我的面吹牛啄栓,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播也祠,決...
    沈念sama閱讀 40,288評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼昙楚,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了齿坷?” 一聲冷哼從身側(cè)響起桂肌,我...
    開封第一講書人閱讀 39,200評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎永淌,沒想到半個(gè)月后崎场,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,644評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡遂蛀,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,837評論 3 336
  • 正文 我和宋清朗相戀三年谭跨,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片李滴。...
    茶點(diǎn)故事閱讀 39,953評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡螃宙,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出所坯,到底是詐尸還是另有隱情谆扎,我是刑警寧澤,帶...
    沈念sama閱讀 35,673評論 5 346
  • 正文 年R本政府宣布芹助,位于F島的核電站堂湖,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏状土。R本人自食惡果不足惜无蜂,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,281評論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望蒙谓。 院中可真熱鬧斥季,春花似錦、人聲如沸累驮。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,889評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽谤专。三九已至躁锡,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間毒租,已是汗流浹背稚铣。 一陣腳步聲響...
    開封第一講書人閱讀 33,011評論 1 269
  • 我被黑心中介騙來泰國打工箱叁, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人惕医。 一個(gè)月前我還...
    沈念sama閱讀 48,119評論 3 370
  • 正文 我出身青樓耕漱,卻偏偏與公主長得像,于是被迫代替她去往敵國和親抬伺。 傳聞我的和親對象是個(gè)殘疾皇子螟够,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,901評論 2 355

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

  • Swift1> Swift和OC的區(qū)別1.1> Swift沒有地址/指針的概念1.2> 泛型1.3> 類型嚴(yán)謹(jǐn) 對...
    cosWriter閱讀 11,101評論 1 32
  • 1.ios高性能編程 (1).內(nèi)層 最小的內(nèi)層平均值和峰值(2).耗電量 高效的算法和數(shù)據(jù)結(jié)構(gòu)(3).初始化時(shí)...
    歐辰_OSR閱讀 29,386評論 8 265
  • 1.反思一過:今天早上不該因?yàn)榇髮毎驯蛔訌拇采贤舷聛懑B,而讓我大發(fā)雷霆峡钓,拿著戒尺追著要打他妓笙。盡管沒有打他,我只是打...
    秋果日記閱讀 124評論 0 0
  • 讀Mobx官方文檔中的最佳實(shí)踐有感能岩,并結(jié)合一些自己項(xiàng)目經(jīng)驗(yàn)寞宫。總結(jié)一下遇到的坑拉鹃,和預(yù)備的解決方案辈赋。 用了半年的red...
    黃祺pinqy閱讀 17,437評論 9 40
  • 區(qū)塊鏈專業(yè)名詞表 Part 1 數(shù)字簽名:Digital Signatures 雙重支付:Double-Spend...
    Jfchris閱讀 1,745評論 4 8