This commit is contained in:
krahets
2023-02-26 18:18:03 +08:00
parent 281b756ddf
commit e82934bc32
34 changed files with 150 additions and 229 deletions

View File

@ -1693,7 +1693,7 @@
</div>
<h2 id="012">0.1.2. &nbsp; 内容结构<a class="headerlink" href="#012" title="Permanent link">&para;</a></h2>
<p>本书主要内容分为复杂度分析、数据结构、算法三个部分。</p>
<p><img alt="hello_algo_mindmap" src="../about_the_book.assets/hello_algo_mindmap.png" /></p>
<p><img alt="Hello 算法内容结构" src="../about_the_book.assets/hello_algo_mindmap.png" /></p>
<h3 id="_1">复杂度分析<a class="headerlink" href="#_1" title="Permanent link">&para;</a></h3>
<p>首先介绍数据结构与算法的评价维度、算法效率的评估方法,引出了计算复杂度概念。</p>
<p>接下来,从 <strong>函数渐近上界</strong> 入手,分别介绍了 <strong>时间复杂度</strong><strong>空间复杂度</strong>,包括推算方法、常见类型、示例等。同时,剖析了 <strong>最差、最佳、平均</strong> 时间复杂度的联系与区别。</p>
@ -1725,8 +1725,8 @@
<li><strong>第二阶段,刷算法题</strong>。可以先从热门题单开刷,推荐<a href="https://leetcode.cn/problem-list/xb9nqhhg/">剑指 Offer</a><a href="https://leetcode.cn/problem-list/2cktkvj/">LeetCode Hot 100</a>,先积累至少 100 道题量,熟悉大多数的算法问题。刚开始刷题时,“遗忘”是最大的困扰点,但这是很正常的,请不要担心。学习中有一种概念叫“周期性回顾”,同一道题隔段时间做一次,在重复 3 轮以上后,往往就能牢记于心了。</li>
<li><strong>第三阶段,搭建知识体系</strong>。在学习方面,可以阅读算法专栏文章、解题框架、算法教材,不断地丰富知识体系。在刷题方面,可以开始采用进阶刷题方案,例如按专题分类、一题多解、一解多题等,相应刷题计划与心得可以在社区中找到,在此不做赘述。</li>
</ul>
<p>作为入门教程,<strong>本书主要对应第一阶段」的学习内容</strong>,致力于使读者更高质量高效地开展第二、三阶段的学习。</p>
<p><img alt="learning_route" src="../suggestions.assets/learning_route.png" /></p>
<p>根据观察,很多同学都是从“第二阶段”开始学习算法的。而作为入门教程,<strong>本书内容主要对应第一阶段</strong>,致力于帮助读者更高效地开展第二、三阶段的学习。</p>
<p><img alt="算法学习路线" src="../suggestions.assets/learning_route.png" /></p>
<h2 id="014">0.1.4. &nbsp; 本书特点<a class="headerlink" href="#014" title="Permanent link">&para;</a></h2>
<p><strong>以实践为主</strong>。我们知道,学习英语期间光啃书本是远远不够的,需要多听、多说、多写,在实践中培养语感、积累经验。编程语言也是一门语言,因此学习方法也应是类似的,需要多看优秀代码、多敲键盘、多思考代码逻辑。</p>
<p>本书的理论部分占少量篇幅,主要分为两类:一是基础且必要的概念知识,以培养读者对于算法的感性认识;二是重要的分类、对比或总结,这是为了帮助你站在更高视角俯瞰各个知识点,形成连点成面的效果。</p>
@ -1747,7 +1747,7 @@
<li>感谢 @squidfunk 给出的写作排版建议,以及优秀开源项目 <a href="https://github.com/squidfunk/mkdocs-material/tree/master">Material-for-MkDocs</a></li>
</ul>
<p>本书鼓励“手脑并用”的学习方式,在这点上受到了《动手学深度学习》很大影响,也在此向各位同学强烈推荐这本著作,包括<a href="https://github.com/d2l-ai/d2l-zh">中文版</a><a href="https://github.com/d2l-ai/d2l-en">英文版</a><a href="https://space.bilibili.com/1567748478">李沐老师 bilibili 主页</a></p>
<p>在写作过程中,我阅读了许多数据结构与算法的书籍与教材,这些著作为本书作出了很好的榜样,保证了本书内容的正确性与质量,感谢前辈们的精彩创作!</p>
<p>在写作过程中,我阅读了许多数据结构与算法的教材与文章,这些著作为本书作出了很好的榜样,保证了本书内容的正确性与质量,感谢前辈们的精彩创作!</p>
<p>感谢父母,你们一贯的支持与鼓励给了我自由度来做这些有趣的事。</p>

View File

@ -1598,7 +1598,7 @@
<li>修改 Markdown 源文件内容,并检查内容正确性,尽量保持排版格式统一;</li>
<li>在页面底部填写更改说明然后单击“Propose file change”按钮页面跳转后点击“Create pull request”按钮发起拉取请求即可。</li>
</ol>
<p><img alt="edit_markdown" src="../contribution.assets/edit_markdown.png" /></p>
<p><img alt="页面编辑按键" src="../contribution.assets/edit_markdown.png" /></p>
<p>图片无法直接修改,需要通过新建 <a href="https://github.com/krahets/hello-algo/issues">Issue</a> 或评论留言来描述图片问题,我会第一时间重新画图并替换图片。</p>
<h2 id="042">0.4.2. &nbsp; 内容创作<a class="headerlink" href="#042" title="Permanent link">&para;</a></h2>
<p>如果您想要参与本开源项目,包括翻译代码至其他编程语言、拓展文章内容等,那么需要实施 Pull Request 工作流程:</p>

View File

@ -1670,7 +1670,6 @@
<h1 id="03">0.3. &nbsp; 编程环境安装<a class="headerlink" href="#03" title="Permanent link">&para;</a></h1>
<p>TODO 视频教程)</p>
<h2 id="031-vscode">0.3.1. &nbsp; 安装 VSCode<a class="headerlink" href="#031-vscode" title="Permanent link">&para;</a></h2>
<p>本书推荐使用开源轻量的 VSCode 作为本地 IDE ,下载并安装 <a href="https://code.visualstudio.com/">VSCode</a></p>
<h2 id="032-java">0.3.2. &nbsp; Java 环境<a class="headerlink" href="#032-java" title="Permanent link">&para;</a></h2>

View File

@ -1657,9 +1657,9 @@
<p><strong>强烈建议通读本节内容,以获取最佳学习体验</strong></p>
<h2 id="021">0.2.1. &nbsp; 行文风格约定<a class="headerlink" href="#021" title="Permanent link">&para;</a></h2>
<p>标题后标注 <code>*</code> 的是选读章节,内容相对较难。如果你的时间有限,建议可以先跳过。</p>
<p>文章中的重要名词会用 <code>「」</code> 括号标注,例如 <code>「数组 Array」</code> 。建议记住这些名词,包括英文翻译,以便后续阅读文献时使用。</p>
<p>文章中的重要名词会用 <code>括号</code> 标注,例如 <code>「数组 Array」</code> 。建议记住这些名词,包括英文翻译,以便后续阅读文献时使用。</p>
<p>重点内容、总起句、总结句会被 <strong>加粗</strong> ,此类文字值得特别关注。</p>
<p>专有名词和有特指含义的词句会使用 <code> </code> 双引号标注,以避免歧义。</p>
<p>专有名词和有特指含义的词句会使用 <code>双引号</code> 标注,以避免歧义。</p>
<p>本书部分放弃了编程语言的注释规范,以换取更加紧凑的内容排版。注释主要分为三种类型:标题注释、内容注释、多行注释。</p>
<div class="tabbed-set tabbed-alternate" data-tabs="1:10"><input checked="checked" id="__tabbed_1_1" name="__tabbed_1" type="radio" /><input id="__tabbed_1_2" name="__tabbed_1" type="radio" /><input id="__tabbed_1_3" name="__tabbed_1" type="radio" /><input id="__tabbed_1_4" name="__tabbed_1" type="radio" /><input id="__tabbed_1_5" name="__tabbed_1" type="radio" /><input id="__tabbed_1_6" name="__tabbed_1" type="radio" /><input id="__tabbed_1_7" name="__tabbed_1" type="radio" /><input id="__tabbed_1_8" name="__tabbed_1" type="radio" /><input id="__tabbed_1_9" name="__tabbed_1" type="radio" /><input id="__tabbed_1_10" name="__tabbed_1" type="radio" /><div class="tabbed-labels"><label for="__tabbed_1_1">Java</label><label for="__tabbed_1_2">C++</label><label for="__tabbed_1_3">Python</label><label for="__tabbed_1_4">Go</label><label for="__tabbed_1_5">JavaScript</label><label for="__tabbed_1_6">TypeScript</label><label for="__tabbed_1_7">C</label><label for="__tabbed_1_8">C#</label><label for="__tabbed_1_9">Swift</label><label for="__tabbed_1_10">Zig</label></div>
<div class="tabbed-content">
@ -1776,7 +1776,7 @@
<h2 id="022">0.2.2. &nbsp; 在动画图解中高效学习<a class="headerlink" href="#022" title="Permanent link">&para;</a></h2>
<p>视频和图片相比于文字的信息密度和结构化程度更高,更容易理解。在本书中,<strong>知识重难点会主要以动画、图解的形式呈现</strong>,而文字的作用则是作为动画和图的解释与补充。</p>
<p>阅读本书时,若发现某段内容提供了动画或图解,<strong>建议你以图为主线</strong>,将文字内容(一般在图的上方)对齐到图中内容,综合来理解。</p>
<p><img alt="animation" src="../suggestions.assets/animation.gif" /></p>
<p><img alt="动画图解示例" src="../suggestions.assets/animation.gif" /></p>
<h2 id="023">0.2.3. &nbsp; 在代码实践中加深理解<a class="headerlink" href="#023" title="Permanent link">&para;</a></h2>
<p>本书的配套代码托管在<a href="https://github.com/krahets/hello-algo">GitHub 仓库</a><strong>源代码包含详细注释,配有测试样例,可以直接运行</strong></p>
<ul>
@ -1790,16 +1790,16 @@
<div class="highlight"><pre><span></span><code><a id="__codelineno-10-1" name="__codelineno-10-1" href="#__codelineno-10-1"></a>git<span class="w"> </span>clone<span class="w"> </span>https://github.com/krahets/hello-algo.git
</code></pre></div>
<p>当然你也可以点击“Download ZIP”直接下载代码压缩包解压即可。</p>
<p><img alt="download_code" src="../suggestions.assets/download_code.png" /></p>
<p><img alt="克隆仓库与下载代码" src="../suggestions.assets/download_code.png" /></p>
<h3 id="3">3) 运行源代码<a class="headerlink" href="#3" title="Permanent link">&para;</a></h3>
<p>若代码块的顶部标有文件名称,则可在仓库 <code>codes</code> 文件夹中找到对应的 <strong>源代码文件</strong></p>
<p><img alt="code_md_to_repo" src="../suggestions.assets/code_md_to_repo.png" /></p>
<p><img alt="代码块与对应的源代码文件" src="../suggestions.assets/code_md_to_repo.png" /></p>
<p>源代码文件可以帮助你省去不必要的调试时间,将精力集中在学习内容上。</p>
<p><img alt="running_code" src="../suggestions.assets/running_code.gif" /></p>
<p><img alt="运行代码示例" src="../suggestions.assets/running_code.gif" /></p>
<h2 id="024">0.2.4. &nbsp; 在提问讨论中共同成长<a class="headerlink" href="#024" title="Permanent link">&para;</a></h2>
<p>阅读本书时,请不要“惯着”那些弄不明白的知识点。<strong>欢迎在评论区留下你的问题</strong>,小伙伴们和我都会给予解答,您一般 2 日内会得到回复。</p>
<p>同时,也希望你可以多花时间逛逛评论区。一方面,可以看看大家遇到了什么问题,反过来查漏补缺,这往往可以引起更加深度的思考。另一方面,也希望你可以慷慨地解答小伙伴们的问题、分享自己的见解,大家互相学习与进步!</p>
<p><img alt="comment" src="../suggestions.assets/comment.gif" /></p>
<p><img alt="评论区示例" src="../suggestions.assets/comment.gif" /></p>