青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

心如止水
Je n'ai pas le temps
posts - 400,comments - 130,trackbacks - 0

  算法是計算機科學領域最重要的基石之一,但卻受到了國內一些程序員的冷落。許多學生看到一些公司在招聘時要求的編程語言五花八門就產(chǎn)生了一種誤解,認為學計算機就是學各種編程語言,或者認為,學習最新的語言、技術、標準就是最好的鋪路方法。其實大家都被這些公司誤導了。編程語言雖然該學,但是學 習計算機算法和理論更重要,因為計算機算法和理論更重要,因為計算機語言和開發(fā)平臺日新月異,但萬變不離其宗的是那些算法和理論,例如數(shù)據(jù)結構、算法、編譯原理、計算機體系結構、關系型數(shù)據(jù)庫原理等等。在“開復學生網(wǎng)”上,有位同學生動地把這些基礎課程比擬為“內功”,把新的語言、技術、標準比擬為“外功”。整天趕時髦的人最后只懂得招式,沒有功力,是不可能成為高手的。

算法與我

  當我在1980年轉入計算機科學系時,還沒有多少人的專業(yè)方向是計算機科學。有許多其他系的人嘲笑我們說:“知道為什么只有你們系要加一個‘科學 ’,而沒有‘物理科學系’或‘化學科學系’嗎?因為人家是真的科學,不需要畫蛇添足,而你們自己心虛,生怕不‘科學’,才這樣欲蓋彌彰。”其實,這點他們徹底弄錯了。真正學懂計算機的人(不只是“編程匠”)都對數(shù)學有相當?shù)脑煸劊饶苡每茖W家的嚴謹思維來求證,也能用工程師的務實手段來解決問題——而這種思維和手段的最佳演繹就是“算法”。

  記得我讀博時寫的Othello對弈軟件獲得了世界冠軍。當時,得第二名的人認為我是靠僥幸才打贏他,不服氣地問我的程序平均每秒能搜索多少步棋,當他發(fā)現(xiàn)我的軟件在搜索效率上比他快60多倍時,才徹底服輸。為什么在同樣的機器上,我可以多做60倍的工作呢?這是因為我用了一個最新的算法,能夠把一個指數(shù)函數(shù)轉換成四個近似的表,只要用常數(shù)時間就可得到近似的答案。在這個例子中,是否用對算法才是能否贏得世界冠軍的關鍵。

  還記得1988年貝爾實驗室副總裁親自來訪問我的學校,目的就是為了想了解為什么他們的語音識別系統(tǒng)比我開發(fā)的慢幾十倍,而且,在擴大至大詞匯系統(tǒng)后,速度差異更有幾百倍之多。他們雖然買了幾臺超級計算機,勉強讓系統(tǒng)跑了起來,但這么貴的計算資源讓他們的產(chǎn)品部門很反感,因為“昂貴”的技術是沒有應用前景的。在與他們探討的過程中,我驚訝地發(fā)現(xiàn)一個O(n*m)的動態(tài)規(guī)劃(Dynamic Programming)居然被他們做成了O (n*n*m)。更驚訝的是,他們還為此發(fā)表了不少文章,甚至為自己的算法起了一個很特別的名字,并將算法提名到一個科學會議里,希望能得到大獎。當時,貝爾實驗室的研究員當然絕頂聰明,但他們全都是學數(shù)學、物理或電機出身,從未學過計算機科學或算法,才犯了這么基本的錯誤。我想那些人以后再也不會嘲笑學計算機科學的人了吧!

網(wǎng)絡時代的算法

  有人也許會說:“今天計算機這么快,算法還重要嗎?”其實永遠不會有太快的計算機,因為我們總會想出新的應用。雖然在摩爾定律的作用下,計算機的計算能力每年都在飛快增長,價格也在不斷下降。可我們不要忘記,需要處理的信息量更是呈指數(shù)級的增長。現(xiàn)在每人每天都會創(chuàng)造出大量數(shù)據(jù)(照片,視頻,語 音,文本等等)。日益先進的紀錄和存儲手段使我們每個人的信息量都在爆炸式的增長。互聯(lián)網(wǎng)的信息流量和日志容量也在飛快增長。在科學研究方面,隨著研究手 段的進步,數(shù)據(jù)量更是達到了前所未有的程度。無論是三維圖形、海量數(shù)據(jù)處理、機器學習、語音識別,都需要極大的計算量。在網(wǎng)絡時代,越來越多的挑戰(zhàn)需要靠 卓越的算法來解決。

  再舉另一個網(wǎng)絡時代的例子。在互聯(lián)網(wǎng)和手機搜索,如果要找附近的咖啡店,那么搜索引擎該怎么處理這個請求呢?最簡單的辦法就是把整個城市的咖啡館都找出來,然后計算出它們的所在位置與你之間的距離,再進行排序,然后返回最近的結果。但該如何計算距離呢?圖論里有不少算法可以解決這個問題。

  這么做也許是最直觀的,但絕對不是最迅速的。如果一個城市只有為數(shù)不多的咖啡館,那么這么做應該沒什么問題,反正計算量不大。但如果一個城市里有很多咖啡館,又有很多用戶都需要類似的搜索,那么服務器所承受的壓力就大多了。在這種情況下,我們該怎樣優(yōu)化算法呢?

  首先,我們可以把整個城市的咖啡館做一次“預處理”。比如,把一個城市分成若干個“格子(grid)”,然后根據(jù)用戶所在的位置把他放到某一個格子里,只對格子里的咖啡館進行距離排序。

  問題又來了,如果格子大小一樣,那么絕大多數(shù)結果都可能出現(xiàn)在市中心的一個格子里,而郊區(qū)的格子里只有極少的結果。在這種情況下,我們應該把市 中心多分出幾個格子。更進一步,格子應該是一個“樹結構”,最頂層是一個大格——整個城市,然后逐層下降,格子越來越小,這樣有利于用戶進行精確搜索—— 如果在最底層的格子里搜索結果不多,用戶可以逐級上升,放大搜索范圍。

  上述算法對咖啡館的例子很實用,但是它具有通用性嗎?答案是否定的。把咖啡館抽象一下,它是一個“點”,如果要搜索一個“面”該怎么辦呢?比 如,用戶想去一個水庫玩,而一個水庫有好幾個入口,那么哪一個離用戶最近呢?這個時候,上述“樹結構”就要改成“r-tree”,因為樹中間的每一個節(jié)點 都是一個范圍,一個有邊界的范圍(參考:http://www.cs.umd.edu/~hjs/rtrees/index.html)。

  通過這個小例子,我們看到,應用程序的要求千變萬化,很多時候需要把一個復雜的問題分解成若干簡單的小問題,然后再選用合適的算法和數(shù)據(jù)結構。

并行算法:Google的核心優(yōu)勢

  上面的例子在Google里就要算是小case了!每天Google的網(wǎng)站要處理十億個以上的搜索,GMail要儲存幾千萬用戶的2G郵箱, Google Earth要讓數(shù)十萬用戶同時在整個地球上遨游,并將合適的圖片經(jīng)過互聯(lián)網(wǎng)提交給每個用戶。如果沒有好的算法,這些應用都無法成為現(xiàn)實。

  在這些的應用中,哪怕是最基本的問題都會給傳統(tǒng)的計算帶來很大的挑戰(zhàn)。例如,每天都有十億以上的用戶訪問Google的網(wǎng)站,使用Google 的服務,也產(chǎn)生很多很多的日志(Log)。因為Log每份每秒都在飛速增加,我們必須有聰明的辦法來進行處理。我曾經(jīng)在面試中問過關于如何對Log進行一 些分析處理的問題,有很多面試者的回答雖然在邏輯上正確,但是實際應用中是幾乎不可行的。按照它們的算法,即便用上幾萬臺機器,我們的處理速度都根不上數(shù) 據(jù)產(chǎn)生的速度。

那么Google是如何解決這些問題的?

  首先,在網(wǎng)絡時代,就算有最好的算法,也要能在并行計算的環(huán)境下執(zhí)行。在Google的數(shù)據(jù)中心,我們使用的是超大的并行計算機。但傳統(tǒng)的并行 算法運行時,效率會在增加機器數(shù)量后迅速降低,也就是說,十臺機器如果有五倍的效果,增加到一千臺時也許就只有幾十倍的效果。這種事半功倍的代價是沒有哪 家公司可以負擔得起的。而且,在許多并行算法中,只要一個結點犯錯誤,所有計算都會前功盡棄。

  那么Google是如何開發(fā)出既有效率又能容錯的并行計算的呢?

  Google最資深的計算機科學家Jeff?Dean認識到,Google所需的絕大部分數(shù)據(jù)處理都可以歸結為一個簡單的并行算法:Map?and?Reduce(http://labs.google.com/papers/mapreduce.html)。 這個算法能夠在很多種計算中達到相當高的效率,而且是可擴展的(也就是說,一千臺機器就算不能達到一千倍的效果,至少也可以達到幾百倍的效果)。 Map?and?Reduce的另外一大特色是它可以利用大批廉價的機器組成功能強大的server?farm。最后,它的容錯性能異常出色,就算一個 server?farm宕掉一半,整個fram依然能夠運行。正是因為這個天才的認識,才有了Map?and?Reduce算法。借助該算法, Google幾乎能無限地增加計算量,與日新月異的互聯(lián)網(wǎng)應用一同成長。

算法并不局限于計算機和網(wǎng)絡

  舉一個計算機領域外的例子:在高能物理研究方面,很多實驗每秒鐘都能幾個TB的數(shù)據(jù)量。但因為處理能力和存儲能力的不足,科學家不得不把絕大部 分未經(jīng)處理的數(shù)據(jù)丟棄掉。可大家要知道,新元素的信息很有可能就藏在我們來不及處理的數(shù)據(jù)里面。同樣的,在其他任何領域里,算法可以改變人類的生活。例如 人類基因的研究,就可能因為算法而發(fā)明新的醫(yī)療方式。在國家安全領域,有效的算法可能避免下一個911的發(fā)生。在氣象方面,算法可以更好地預測未來天災的 發(fā)生,以拯救生命。

  所以,如果你把計算機的發(fā)展放到應用和數(shù)據(jù)飛速增長的大環(huán)境下,你一定會發(fā)現(xiàn);算法的重要性不是在日益減小,而是在日益加強。


posted on 2010-02-08 18:51 lee1r 閱讀(951) 評論(3)  編輯 收藏 引用 所屬分類: Programming Diary

FeedBack:
# re: 李開復:算法的力量
2010-02-08 20:23 | Sunshine Alike
痛哭,明知算法很重要,就是學不好~  回復  更多評論
  
# re: 李開復:算法的力量[未登錄]
2010-02-08 20:24 | .....
.............  回復  更多評論
  
# re: 李開復:算法的力量
2010-02-12 16:09 | 煙皚
不錯,謝博主分享了~  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲图片欧美日产| 欧美一区二区三区啪啪| 中日韩高清电影网| 夜夜夜久久久| 亚洲成人原创| 国产欧美精品| 亚洲成人在线免费| 国产一区二区三区久久久| 欧美视频亚洲视频| 欧美激情视频一区二区三区在线播放 | 国内在线观看一区二区三区| 亚洲欧美日韩国产一区二区三区 | 一本色道久久99精品综合| 91久久精品国产| 亚洲一区在线播放| 欧美日韩精品高清| 午夜精品视频一区| 毛片一区二区三区| 欧美freesex8一10精品| 国产精品99久久久久久久vr| 久久精品二区| 亚洲一区二区免费看| 久久福利电影| 国产一区在线看| 免费日韩av| 欧美日韩一区二区三区在线看 | 欧美承认网站| 欧美大片一区二区三区| 亚洲精品久久久久久下一站 | 亚洲品质自拍| 久久综合久久综合久久| 午夜天堂精品久久久久| 欧美日韩在线免费| 先锋影音国产精品| 蜜桃av综合| 亚洲一区二区三区在线看| 亚洲欧美中文日韩v在线观看| 红桃视频国产精品| 亚洲精品视频一区| 国产日韩在线一区| 亚洲免费电影在线观看| 国语自产精品视频在线看| 999在线观看精品免费不卡网站| 极品少妇一区二区三区| 亚洲在线观看视频| 亚洲桃色在线一区| 欧美电影免费观看大全| 在线一区欧美| 欧美精品在线一区| 欧美激情中文字幕乱码免费| 狠狠色丁香久久婷婷综合丁香| 亚洲人体1000| 亚洲精品一区二区三区在线观看| 欧美在线一二三区| 久久久久久久久久久久久久一区| 欧美日韩卡一卡二| 99pao成人国产永久免费视频| 亚洲美女av在线播放| 国产精品v欧美精品v日韩精品| 亚洲欧洲一区二区天堂久久 | 久久精品30| 国产精品午夜在线观看| 亚洲精品九九| 国产精品a级| 性做久久久久久免费观看欧美| 亚洲高清免费在线| 欧美精品自拍偷拍动漫精品| 久久久久久久久一区二区| 午夜视频一区| 最新69国产成人精品视频免费| 亚洲午夜精品福利| 国产欧美日韩| 欧美成人精品三级在线观看| 亚洲肉体裸体xxxx137| 欧美在线日韩精品| 亚洲肉体裸体xxxx137| 国产精品jizz在线观看美国| 欧美电影免费观看大全| 美女久久网站| 噜噜爱69成人精品| 老司机aⅴ在线精品导航| 欧美一级免费视频| 亚洲永久精品大片| 亚洲欧美日韩精品久久奇米色影视| 亚洲激情一区二区三区| 亚洲福利久久| 亚洲欧洲另类| 亚洲精品在线免费观看视频| 亚洲精品一区二区三区樱花| 亚洲三级免费| 一区二区日韩| 亚洲影视在线| 久久久精品免费视频| 鲁鲁狠狠狠7777一区二区| 免费的成人av| 国产精品激情偷乱一区二区∴| 国产精品视频免费观看| 红桃视频成人| 一区二区三区视频在线播放| 亚洲免费一级电影| 久久久精品一区二区三区| 免费成人av在线看| 亚洲制服少妇| 最新国产乱人伦偷精品免费网站 | 欧美成人精品福利| 亚洲毛片av在线| 午夜精品久久久久久久99热浪潮| 久久国产精品电影| 欧美性猛交视频| 亚洲国产成人精品视频| 午夜精品一区二区三区在线播放| 欧美一级播放| 亚洲国产精品一区二区第四页av| 亚洲一二三区精品| 欧美日韩第一区日日骚| 韩国欧美一区| 中文精品视频| 久久婷婷国产综合国色天香| 日韩视频免费在线观看| 久久se精品一区二区| 国产精品黄色在线观看| 亚洲精品免费电影| 久久人人97超碰人人澡爱香蕉 | 免费成人你懂的| 亚洲欧美激情诱惑| 国产精品久久99| 亚洲一区二区在线视频| 亚洲伦伦在线| 国产乱码精品1区2区3区| 亚洲一级二级| 中文网丁香综合网| 国产精品视频免费在线观看| 亚洲免费在线视频| 亚洲久久成人| 欧美日本一区二区视频在线观看| 136国产福利精品导航| 欧美激情视频在线播放 | 欧美呦呦网站| 欧美亚洲免费电影| 在线精品一区| 亚洲精一区二区三区| 一区二区三区日韩在线观看| 国产精品亚洲成人| 免费观看亚洲视频大全| 欧美激情片在线观看| 亚洲综合第一页| 久久一日本道色综合久久| 亚洲欧洲日韩在线| 午夜精品久久久久久久久久久久 | 99在线精品视频在线观看| 国产精品久久久久久av下载红粉| 久久精品午夜| 欧美精品1区2区3区| 性欧美暴力猛交69hd| 美女被久久久| 老**午夜毛片一区二区三区| 欧美手机在线视频| 亚洲激情综合| 亚洲国产成人tv| 欧美在线观看一区二区三区| 亚洲一区二区三区精品动漫| 嫩模写真一区二区三区三州| 久久久久久久久久久成人| 欧美日韩另类在线| 欧美黄色精品| 亚洲激情小视频| 免费亚洲婷婷| 亚洲狠狠丁香婷婷综合久久久| 国产午夜精品一区理论片飘花 | 老司机精品导航| 久久精视频免费在线久久完整在线看| 久久夜色精品亚洲噜噜国产mv| 亚洲天堂网站在线观看视频| 欧美日韩精品一区二区| 99精品欧美一区二区蜜桃免费| 99精品国产高清一区二区| 欧美乱在线观看| 亚洲欧美国产毛片在线| 久久视频一区| 亚洲国产精品99久久久久久久久| 久久男人av资源网站| 亚洲第一中文字幕在线观看| 亚洲人成免费| 国产伦精品一区二区三区免费迷| 久久一区免费| 亚洲三级影院| 欧美性猛片xxxx免费看久爱| 亚洲欧美日韩久久精品| 欧美激情国产精品| 99天天综合性| 国产日韩欧美亚洲| 麻豆乱码国产一区二区三区| 一区二区三区高清在线| 男同欧美伦乱| 欧美在线亚洲一区| 日韩视频在线免费| 黄色亚洲免费| 国产一区白浆| 国产精品一二三四区| 欧美日韩美女在线观看|