V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
hetong_007
V2EX  ›  问与答

如果想从0基础开始学习算法,应该用什么参考书比较好?

  •  
  •   hetong_007 · 2012-06-05 20:52:33 +08:00 · 6044 次点击
    这是一个创建于 4556 天前的主题,其中的信息可能已经有所发展或是发生改变。
    RT,觉得《算法导论》这本书太难了,一下子也不知道选择哪本书~

    看了书之后,应该去哪些题库找习题进行操练呢?谢谢~
    18 条回复    1970-01-01 08:00:00 +08:00
    gDD
        1
    gDD  
       2012-06-05 20:58:56 +08:00   ❤️ 1
    virushuo
        2
    virushuo  
       2012-06-05 21:00:53 +08:00   ❤️ 2
    sicp 这不是一本纯粹讲算法的书,但是讲了算法的思维方式和程序工作方式。习题都做了收获会很大。
    qiukun
        3
    qiukun  
       2012-06-05 21:09:10 +08:00   ❤️ 1
    kid7st
        4
    kid7st  
       2012-06-05 22:41:06 +08:00   ❤️ 1
    楼上那本似乎更难吧..如果有C++基础的话,推荐这一本.http://book.douban.com/subject/1971825/
    txx
        5
    txx  
       2012-06-05 22:45:16 +08:00   ❤️ 1
    直接刷USACO拉~~~ 第一章 都是水题加讲解...网上的资源也足够多...
    看书 不如直接刷题来得快
    kid7st
        6
    kid7st  
       2012-06-05 22:46:43 +08:00   ❤️ 1
    @txx 非常赞同!直接刷题.code to learn
    qiukun
        7
    qiukun  
       2012-06-06 18:32:55 +08:00   ❤️ 1
    都用过,个人觉得 USACO 不如以上我推荐的书。
    mew7wo
        8
    mew7wo  
       2012-06-06 20:05:39 +08:00   ❤️ 1
    为何楼上几个一看到算法就直接和ACM,刷题挂上钩了。
    我觉得它们两关系并不是那么的紧密。
    Gestalt
        9
    Gestalt  
       2012-06-06 23:09:10 +08:00   ❤️ 1
    @hetong_007
    建议先了解一些基础的东西,《算法导论》的第一章讲的就非常好。《数据结构与算法分析(Data Structures and Algorithm Analysis in C, Second Edition)》作为一部了解基本算法思想且较为通俗的书觉得还可以。《挑战编程——程序设计竞赛训练手册》这本书作为一本练习题的目录比较适合。
    如果LZ是考虑学习算法而非准备竞赛的话题库推荐SPOJ。上面的可以提交的语言是我见过最多的题库。
    另外不推荐为算法竞赛设计的书,一些实际很常见算法(如近似类的算法和文件压缩算法)短时限的算法竞赛都很少涉及。
    sampeng
        10
    sampeng  
       2012-06-06 23:20:26 +08:00   ❤️ 1
    算法导论。。。你觉得难就对了。。。
    我觉得这本书真心是在影响我一辈子的编程过程。。
    原来只是快速扫了。。现在工作中经常会用到,拿出来再看看加上网上再找资料辅佐一下。。真的是豁然开朗的感觉。
    算法导论我觉得不是一本看一遍就扔的书
    ichigo
        11
    ichigo  
       2012-06-06 23:22:35 +08:00   ❤️ 1
    数据结构
    fatmurphy
        12
    fatmurphy  
       2012-06-06 23:44:00 +08:00   ❤️ 1
    @mew7wo 关系确实不紧密。但是从另外一个角度来看,学习算法并不能只是"看懂"了算法要表大的内容,还应该尽量达到运用自如的地步,否则作用很有限。从这个角度来说ACM练习题是一个效率不高但是确实有效果的练习手段。
    kerie
        13
    kerie  
       2012-06-07 00:11:14 +08:00   ❤️ 1
    数据结构 + 1
    数据结构比算法要实用的多
    iwinux
        14
    iwinux  
       2012-06-07 00:15:23 +08:00
    惊现何同学……如果你学过C的话,其实 The Algorithm Design Manual 是个不错的选择,前面几章挺容易懂的,不会像《算法导论》一样一坨坨的公式。
    hetong_007
        15
    hetong_007  
    OP
       2012-06-07 11:15:34 +08:00
    @iwinux 悄悄说我是去教别人
    iwinux
        16
    iwinux  
       2012-06-07 11:51:14 +08:00
    @hetong_007 噗……你把他忽悠进我们实验室吧 >.<
    humiaozuzu
        17
    humiaozuzu  
       2012-06-07 11:55:14 +08:00
    学习工程里面的算法还是acm的算法?
    hetong_007
        18
    hetong_007  
    OP
       2012-06-07 23:27:32 +08:00
    @iwinux 不是中大的╮(╯_╰)╭
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1056 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 29ms · UTC 19:57 · PVG 03:57 · LAX 11:57 · JFK 14:57
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.