mirror of
https://github.com/krahets/hello-algo.git
synced 2025-07-11 01:22:51 +08:00
deploy
This commit is contained in:
@ -361,35 +361,28 @@
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#013" class="md-nav__link">
|
||||
0.1.3. 配套代码
|
||||
0.1.3. 本书定位
|
||||
</a>
|
||||
|
||||
</li>
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#014" class="md-nav__link">
|
||||
0.1.4. 风格约定
|
||||
0.1.4. 本书特点
|
||||
</a>
|
||||
|
||||
</li>
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#015" class="md-nav__link">
|
||||
0.1.5. 本书特点 *
|
||||
0.1.5. 致谢
|
||||
</a>
|
||||
|
||||
</li>
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#016" class="md-nav__link">
|
||||
0.1.6. 致谢
|
||||
</a>
|
||||
|
||||
</li>
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#017" class="md-nav__link">
|
||||
0.1.7. 作者简介
|
||||
0.1.6. 作者简介
|
||||
</a>
|
||||
|
||||
</li>
|
||||
@ -1636,35 +1629,28 @@
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#013" class="md-nav__link">
|
||||
0.1.3. 配套代码
|
||||
0.1.3. 本书定位
|
||||
</a>
|
||||
|
||||
</li>
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#014" class="md-nav__link">
|
||||
0.1.4. 风格约定
|
||||
0.1.4. 本书特点
|
||||
</a>
|
||||
|
||||
</li>
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#015" class="md-nav__link">
|
||||
0.1.5. 本书特点 *
|
||||
0.1.5. 致谢
|
||||
</a>
|
||||
|
||||
</li>
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#016" class="md-nav__link">
|
||||
0.1.6. 致谢
|
||||
</a>
|
||||
|
||||
</li>
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#017" class="md-nav__link">
|
||||
0.1.7. 作者简介
|
||||
0.1.6. 作者简介
|
||||
</a>
|
||||
|
||||
</li>
|
||||
@ -1694,34 +1680,34 @@
|
||||
|
||||
|
||||
<h1 id="01">0.1. 关于本书<a class="headerlink" href="#01" title="Permanent link">¶</a></h1>
|
||||
<div class="admonition tip">
|
||||
<p class="admonition-title">Tip</p>
|
||||
<p>对于本章内容,建议通读<a href="https://www.hello-algo.com/chapter_preface/suggestions/">如何使用本书</a>,其余章节可根据需求选读。</p>
|
||||
</div>
|
||||
<p>五年前发生的一件事,成为了我职业生涯的重要转折点。当时的我在交大读研,对互联网求职一无所知,但仍然硬着头皮申请了 Microsoft 软件工程师实习。面试官让我在白板上写出“快速排序”代码,我畏畏缩缩地写了一个“冒泡排序”,并且还写错了<code>(ToT)</code> 。从面试官的表情上,我看到了一个大大的 "GG" 。</p>
|
||||
<p>此次失利倒逼我开始刷算法题。我采用“扫雷游戏”式的学习方法,两眼一抹黑刷题,扫到不会的“雷”就通过查资料把它“排掉”,配合周期性总结,逐渐形成了数据结构与算法的知识图景。幸运地,我在秋招斩获了多家大厂的 Offer 。</p>
|
||||
<p>回想自己当初在“扫雷式”刷题中被炸的满头包的痛苦,思考良久,我意识到一本“前期刷题必看”的读物可以使算法小白少走许多弯路。写作意愿滚滚袭来,那就动笔吧:</p>
|
||||
<p>回想自己当初在“扫雷式”刷题中被炸的满头包的痛苦,思考良久,<strong>我意识到一本“前期刷题必看”的读物可以使算法小白少走许多弯路</strong>。写作意愿滚滚袭来,那就动笔吧:</p>
|
||||
<h4 align="center"> Hello,算法! </h4>
|
||||
|
||||
<h2 id="011">0.1.1. 读者对象<a class="headerlink" href="#011" title="Permanent link">¶</a></h2>
|
||||
<p>如果您是「算法初学者」,完全没有接触过算法,或者已经有少量刷题,对数据结构与算法有朦胧的理解,在会与不会之间反复横跳,那么这本书就是为您而写!本书能够带来:</p>
|
||||
<ul>
|
||||
<li>带领你完整学习数据结构与算法,初步搭建知识框架,使刷题事半功倍;</li>
|
||||
<li>提供写法标准整洁、可一键运行的配套代码,帮助你养成良好的编程习惯;</li>
|
||||
</ul>
|
||||
<p>如果您是「算法老手」,已经积累一定刷题量,接触过大多数题型,那么本书内容对你来说可能稍显基础,但仍能够带来以下价值:</p>
|
||||
<ul>
|
||||
<li>本书篇幅不长,并且包含较多对比性和总结性的内容,可以帮助你回顾与梳理算法知识体系;</li>
|
||||
<li>源代码实现了各种经典数据结构和算法,可以作为“刷题工具库”或“算法实现字典”来使用;</li>
|
||||
</ul>
|
||||
<p>如果您是「算法大佬」,请受我膜拜!希望您可以抽时间提出意见建议,或者<a href="https://www.hello-algo.com/chapter_preface/contribution/">一起参与创作</a>,帮助各位同学获取更好的学习内容,感谢!</p>
|
||||
<div class="admonition success">
|
||||
<p class="admonition-title">前置条件</p>
|
||||
<p>您需要至少具备任一语言的编程基础,能够阅读和编写简单代码。</p>
|
||||
</div>
|
||||
<p>如果您是 <strong>算法初学者</strong>,完全没有接触过算法,或者已经有少量刷题,对数据结构与算法有朦胧的理解,在会与不会之间反复横跳,那么这本书就是为您而写!本书能够带来:</p>
|
||||
<ul>
|
||||
<li>了解刷题所需的 <strong>数据结构</strong>,包括常用操作、优势和劣势、典型应用、实现方法等。</li>
|
||||
<li>学习各类 <strong>算法</strong>,介绍算法的设计思想、运行效率、优势劣势、实现方法等。</li>
|
||||
<li>可一键运行的 <strong>配套代码</strong>,包含详细注释,帮助你通过实践加深理解。</li>
|
||||
</ul>
|
||||
<p>如果您是 <strong>算法熟练工</strong>,已经积累一定刷题量,接触过大多数题型,那么本书内容对你来说可能稍显基础,但仍能够带来以下价值:</p>
|
||||
<ul>
|
||||
<li>本书篇幅不长,可以帮助你提纲挈领地回顾算法知识。</li>
|
||||
<li>书中包含许多对比性、总结性的算法内容,可以帮助你梳理算法知识体系。</li>
|
||||
<li>源代码实现了各种经典数据结构和算法,可以作为“刷题工具库”来使用。</li>
|
||||
</ul>
|
||||
<p>如果您是 <strong>算法大佬</strong>,请受我膜拜!希望您可以抽时间提出意见建议,或者<a href="https://www.hello-algo.com/chapter_preface/contribution/">一起参与创作</a>,帮助各位同学获取更好的学习内容,感谢!</p>
|
||||
<h2 id="012">0.1.2. 内容结构<a class="headerlink" href="#012" title="Permanent link">¶</a></h2>
|
||||
<p>本书主要内容分为复杂度分析、数据结构、算法三个部分。</p>
|
||||
<p><img alt="hello_algo_mindmap" src="../about_the_book.assets/hello_algo_mindmap.png" /></p>
|
||||
<p align="center"> Fig. 知识点思维导图 </p>
|
||||
|
||||
<h3 id="_1">复杂度分析<a class="headerlink" href="#_1" title="Permanent link">¶</a></h3>
|
||||
<p>首先介绍数据结构与算法的评价维度、算法效率的评估方法,引出了计算复杂度概念。</p>
|
||||
<p>接下来,从 <strong>函数渐近上界</strong> 入手,分别介绍了 <strong>时间复杂度</strong> 和 <strong>空间复杂度</strong>,包括推算方法、常见类型、示例等。同时,剖析了 <strong>最差、最佳、平均</strong> 时间复杂度的联系与区别。</p>
|
||||
@ -1746,138 +1732,16 @@
|
||||
<li>实现方法:完整的算法实现,以及优化措施;</li>
|
||||
<li>示例题目:结合例题加深理解;</li>
|
||||
</ul>
|
||||
<h2 id="013">0.1.3. 配套代码<a class="headerlink" href="#013" title="Permanent link">¶</a></h2>
|
||||
<p>完整代码托管在 <a href="https://github.com/krahets/hello-algo">GitHub 仓库</a> ,皆可一键运行。</p>
|
||||
<div class="admonition tip">
|
||||
<p class="admonition-title">前置工作</p>
|
||||
<ol>
|
||||
<li><a href="https://www.hello-algo.com/chapter_preface/installation/">编程环境安装</a> ,若有请跳过</li>
|
||||
<li>代码下载与使用方法请见 <a href="https://www.hello-algo.com/chapter_preface/suggestions/#_4">如何使用本书</a></li>
|
||||
</ol>
|
||||
</div>
|
||||
<h2 id="014">0.1.4. 风格约定<a class="headerlink" href="#014" title="Permanent link">¶</a></h2>
|
||||
<h2 id="013">0.1.3. 本书定位<a class="headerlink" href="#013" title="Permanent link">¶</a></h2>
|
||||
<p>总体上看,我认为可将学习数据结构与算法的过程分为三个阶段。</p>
|
||||
<ul>
|
||||
<li>标题后标注 * 符号的是选读章节,如果你的时间有限,可以先跳过这些章节。</li>
|
||||
<li>文章中的重要名词会用「」符号标注,例如「数组 Array」。名词混淆会导致不必要的歧义,因此最好可以记住这类名词(包括中文和英文),以便后续阅读文献时使用。</li>
|
||||
<li>重点内容、总起句、总结句会被 <strong>加粗</strong>,此类文字值得特别关注。</li>
|
||||
<li>专有名词和有特指含义的词句会使用 “ ” 标注,以避免歧义。</li>
|
||||
<li>在工程应用中,每种语言都有注释规范;而本书放弃了一部分的注释规范性,以换取更加紧凑的内容排版。注释主要分为三种类型:标题注释、内容注释、多行注释。</li>
|
||||
<li><strong>第一阶段,算法入门</strong>。熟悉各种数据结构的特点、用法,学习各种算法的原理、流程、用途、效率等。</li>
|
||||
<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>
|
||||
<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">
|
||||
<div class="tabbed-block">
|
||||
<div class="highlight"><pre><span></span><code><a id="__codelineno-0-1" name="__codelineno-0-1" href="#__codelineno-0-1"></a><span class="cm">/* 标题注释,用于标注函数、类、测试样例等 */</span>
|
||||
<a id="__codelineno-0-2" name="__codelineno-0-2" href="#__codelineno-0-2"></a>
|
||||
<a id="__codelineno-0-3" name="__codelineno-0-3" href="#__codelineno-0-3"></a><span class="c1">// 内容注释,用于详解代码</span>
|
||||
<a id="__codelineno-0-4" name="__codelineno-0-4" href="#__codelineno-0-4"></a>
|
||||
<a id="__codelineno-0-5" name="__codelineno-0-5" href="#__codelineno-0-5"></a><span class="cm">/**</span>
|
||||
<a id="__codelineno-0-6" name="__codelineno-0-6" href="#__codelineno-0-6"></a><span class="cm"> * 多行</span>
|
||||
<a id="__codelineno-0-7" name="__codelineno-0-7" href="#__codelineno-0-7"></a><span class="cm"> * 注释</span>
|
||||
<a id="__codelineno-0-8" name="__codelineno-0-8" href="#__codelineno-0-8"></a><span class="cm"> */</span>
|
||||
</code></pre></div>
|
||||
</div>
|
||||
<div class="tabbed-block">
|
||||
<div class="highlight"><pre><span></span><code><a id="__codelineno-1-1" name="__codelineno-1-1" href="#__codelineno-1-1"></a><span class="cm">/* 标题注释,用于标注函数、类、测试样例等 */</span>
|
||||
<a id="__codelineno-1-2" name="__codelineno-1-2" href="#__codelineno-1-2"></a>
|
||||
<a id="__codelineno-1-3" name="__codelineno-1-3" href="#__codelineno-1-3"></a><span class="c1">// 内容注释,用于详解代码</span>
|
||||
<a id="__codelineno-1-4" name="__codelineno-1-4" href="#__codelineno-1-4"></a>
|
||||
<a id="__codelineno-1-5" name="__codelineno-1-5" href="#__codelineno-1-5"></a><span class="cm">/**</span>
|
||||
<a id="__codelineno-1-6" name="__codelineno-1-6" href="#__codelineno-1-6"></a><span class="cm"> * 多行</span>
|
||||
<a id="__codelineno-1-7" name="__codelineno-1-7" href="#__codelineno-1-7"></a><span class="cm"> * 注释</span>
|
||||
<a id="__codelineno-1-8" name="__codelineno-1-8" href="#__codelineno-1-8"></a><span class="cm"> */</span>
|
||||
</code></pre></div>
|
||||
</div>
|
||||
<div class="tabbed-block">
|
||||
<div class="highlight"><pre><span></span><code><a id="__codelineno-2-1" name="__codelineno-2-1" href="#__codelineno-2-1"></a><span class="sd">""" 标题注释,用于标注函数、类、测试样例等 """</span>
|
||||
<a id="__codelineno-2-2" name="__codelineno-2-2" href="#__codelineno-2-2"></a>
|
||||
<a id="__codelineno-2-3" name="__codelineno-2-3" href="#__codelineno-2-3"></a><span class="c1"># 内容注释,用于详解代码</span>
|
||||
<a id="__codelineno-2-4" name="__codelineno-2-4" href="#__codelineno-2-4"></a>
|
||||
<a id="__codelineno-2-5" name="__codelineno-2-5" href="#__codelineno-2-5"></a><span class="sd">"""</span>
|
||||
<a id="__codelineno-2-6" name="__codelineno-2-6" href="#__codelineno-2-6"></a><span class="sd">多行</span>
|
||||
<a id="__codelineno-2-7" name="__codelineno-2-7" href="#__codelineno-2-7"></a><span class="sd">注释</span>
|
||||
<a id="__codelineno-2-8" name="__codelineno-2-8" href="#__codelineno-2-8"></a><span class="sd">"""</span>
|
||||
</code></pre></div>
|
||||
</div>
|
||||
<div class="tabbed-block">
|
||||
<div class="highlight"><pre><span></span><code><a id="__codelineno-3-1" name="__codelineno-3-1" href="#__codelineno-3-1"></a><span class="cm">/* 标题注释,用于标注函数、类、测试样例等 */</span>
|
||||
<a id="__codelineno-3-2" name="__codelineno-3-2" href="#__codelineno-3-2"></a>
|
||||
<a id="__codelineno-3-3" name="__codelineno-3-3" href="#__codelineno-3-3"></a><span class="c1">// 内容注释,用于详解代码</span>
|
||||
<a id="__codelineno-3-4" name="__codelineno-3-4" href="#__codelineno-3-4"></a>
|
||||
<a id="__codelineno-3-5" name="__codelineno-3-5" href="#__codelineno-3-5"></a><span class="cm">/**</span>
|
||||
<a id="__codelineno-3-6" name="__codelineno-3-6" href="#__codelineno-3-6"></a><span class="cm"> * 多行</span>
|
||||
<a id="__codelineno-3-7" name="__codelineno-3-7" href="#__codelineno-3-7"></a><span class="cm"> * 注释</span>
|
||||
<a id="__codelineno-3-8" name="__codelineno-3-8" href="#__codelineno-3-8"></a><span class="cm"> */</span>
|
||||
</code></pre></div>
|
||||
</div>
|
||||
<div class="tabbed-block">
|
||||
<div class="highlight"><pre><span></span><code><a id="__codelineno-4-1" name="__codelineno-4-1" href="#__codelineno-4-1"></a><span class="cm">/* 标题注释,用于标注函数、类、测试样例等 */</span>
|
||||
<a id="__codelineno-4-2" name="__codelineno-4-2" href="#__codelineno-4-2"></a>
|
||||
<a id="__codelineno-4-3" name="__codelineno-4-3" href="#__codelineno-4-3"></a><span class="c1">// 内容注释,用于详解代码</span>
|
||||
<a id="__codelineno-4-4" name="__codelineno-4-4" href="#__codelineno-4-4"></a>
|
||||
<a id="__codelineno-4-5" name="__codelineno-4-5" href="#__codelineno-4-5"></a><span class="cm">/**</span>
|
||||
<a id="__codelineno-4-6" name="__codelineno-4-6" href="#__codelineno-4-6"></a><span class="cm"> * 多行</span>
|
||||
<a id="__codelineno-4-7" name="__codelineno-4-7" href="#__codelineno-4-7"></a><span class="cm"> * 注释</span>
|
||||
<a id="__codelineno-4-8" name="__codelineno-4-8" href="#__codelineno-4-8"></a><span class="cm"> */</span>
|
||||
</code></pre></div>
|
||||
</div>
|
||||
<div class="tabbed-block">
|
||||
<div class="highlight"><pre><span></span><code><a id="__codelineno-5-1" name="__codelineno-5-1" href="#__codelineno-5-1"></a><span class="cm">/* 标题注释,用于标注函数、类、测试样例等 */</span>
|
||||
<a id="__codelineno-5-2" name="__codelineno-5-2" href="#__codelineno-5-2"></a>
|
||||
<a id="__codelineno-5-3" name="__codelineno-5-3" href="#__codelineno-5-3"></a><span class="c1">// 内容注释,用于详解代码</span>
|
||||
<a id="__codelineno-5-4" name="__codelineno-5-4" href="#__codelineno-5-4"></a>
|
||||
<a id="__codelineno-5-5" name="__codelineno-5-5" href="#__codelineno-5-5"></a><span class="cm">/**</span>
|
||||
<a id="__codelineno-5-6" name="__codelineno-5-6" href="#__codelineno-5-6"></a><span class="cm"> * 多行</span>
|
||||
<a id="__codelineno-5-7" name="__codelineno-5-7" href="#__codelineno-5-7"></a><span class="cm"> * 注释</span>
|
||||
<a id="__codelineno-5-8" name="__codelineno-5-8" href="#__codelineno-5-8"></a><span class="cm"> */</span>
|
||||
</code></pre></div>
|
||||
</div>
|
||||
<div class="tabbed-block">
|
||||
<div class="highlight"><pre><span></span><code><a id="__codelineno-6-1" name="__codelineno-6-1" href="#__codelineno-6-1"></a><span class="cm">/* 标题注释,用于标注函数、类、测试样例等 */</span>
|
||||
<a id="__codelineno-6-2" name="__codelineno-6-2" href="#__codelineno-6-2"></a>
|
||||
<a id="__codelineno-6-3" name="__codelineno-6-3" href="#__codelineno-6-3"></a><span class="c1">// 内容注释,用于详解代码</span>
|
||||
<a id="__codelineno-6-4" name="__codelineno-6-4" href="#__codelineno-6-4"></a>
|
||||
<a id="__codelineno-6-5" name="__codelineno-6-5" href="#__codelineno-6-5"></a><span class="cm">/**</span>
|
||||
<a id="__codelineno-6-6" name="__codelineno-6-6" href="#__codelineno-6-6"></a><span class="cm"> * 多行</span>
|
||||
<a id="__codelineno-6-7" name="__codelineno-6-7" href="#__codelineno-6-7"></a><span class="cm"> * 注释</span>
|
||||
<a id="__codelineno-6-8" name="__codelineno-6-8" href="#__codelineno-6-8"></a><span class="cm"> */</span>
|
||||
</code></pre></div>
|
||||
</div>
|
||||
<div class="tabbed-block">
|
||||
<div class="highlight"><pre><span></span><code><a id="__codelineno-7-1" name="__codelineno-7-1" href="#__codelineno-7-1"></a><span class="cm">/* 标题注释,用于标注函数、类、测试样例等 */</span>
|
||||
<a id="__codelineno-7-2" name="__codelineno-7-2" href="#__codelineno-7-2"></a>
|
||||
<a id="__codelineno-7-3" name="__codelineno-7-3" href="#__codelineno-7-3"></a><span class="c1">// 内容注释,用于详解代码</span>
|
||||
<a id="__codelineno-7-4" name="__codelineno-7-4" href="#__codelineno-7-4"></a>
|
||||
<a id="__codelineno-7-5" name="__codelineno-7-5" href="#__codelineno-7-5"></a><span class="cm">/**</span>
|
||||
<a id="__codelineno-7-6" name="__codelineno-7-6" href="#__codelineno-7-6"></a><span class="cm"> * 多行</span>
|
||||
<a id="__codelineno-7-7" name="__codelineno-7-7" href="#__codelineno-7-7"></a><span class="cm"> * 注释</span>
|
||||
<a id="__codelineno-7-8" name="__codelineno-7-8" href="#__codelineno-7-8"></a><span class="cm"> */</span>
|
||||
</code></pre></div>
|
||||
</div>
|
||||
<div class="tabbed-block">
|
||||
<div class="highlight"><pre><span></span><code><a id="__codelineno-8-1" name="__codelineno-8-1" href="#__codelineno-8-1"></a><span class="cm">/* 标题注释,用于标注函数、类、测试样例等 */</span>
|
||||
<a id="__codelineno-8-2" name="__codelineno-8-2" href="#__codelineno-8-2"></a>
|
||||
<a id="__codelineno-8-3" name="__codelineno-8-3" href="#__codelineno-8-3"></a><span class="c1">// 内容注释,用于详解代码</span>
|
||||
<a id="__codelineno-8-4" name="__codelineno-8-4" href="#__codelineno-8-4"></a>
|
||||
<a id="__codelineno-8-5" name="__codelineno-8-5" href="#__codelineno-8-5"></a><span class="cm">/**</span>
|
||||
<a id="__codelineno-8-6" name="__codelineno-8-6" href="#__codelineno-8-6"></a><span class="cm"> * 多行</span>
|
||||
<a id="__codelineno-8-7" name="__codelineno-8-7" href="#__codelineno-8-7"></a><span class="cm"> * 注释</span>
|
||||
<a id="__codelineno-8-8" name="__codelineno-8-8" href="#__codelineno-8-8"></a><span class="cm"> */</span>
|
||||
</code></pre></div>
|
||||
</div>
|
||||
<div class="tabbed-block">
|
||||
<div class="highlight"><pre><span></span><code><a id="__codelineno-9-1" name="__codelineno-9-1" href="#__codelineno-9-1"></a><span class="c1">// 标题注释,用于标注函数、类、测试样例等</span>
|
||||
<a id="__codelineno-9-2" name="__codelineno-9-2" href="#__codelineno-9-2"></a>
|
||||
<a id="__codelineno-9-3" name="__codelineno-9-3" href="#__codelineno-9-3"></a><span class="c1">// 内容注释,用于详解代码</span>
|
||||
<a id="__codelineno-9-4" name="__codelineno-9-4" href="#__codelineno-9-4"></a>
|
||||
<a id="__codelineno-9-5" name="__codelineno-9-5" href="#__codelineno-9-5"></a><span class="c1">// 多行</span>
|
||||
<a id="__codelineno-9-6" name="__codelineno-9-6" href="#__codelineno-9-6"></a><span class="c1">// 注释</span>
|
||||
</code></pre></div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<h2 id="015">0.1.5. 本书特点 *<a class="headerlink" href="#015" title="Permanent link">¶</a></h2>
|
||||
<details class="abstract">
|
||||
<summary>默认折叠,可以跳过</summary>
|
||||
<p>作为入门教程,<strong>本书主要对应「第一阶段」的学习内容</strong>,致力于使读者更高质量高效地开展第二、三阶段的学习。</p>
|
||||
<p><img alt="learning_route" src="../suggestions.assets/learning_route.png" /></p>
|
||||
<h2 id="014">0.1.4. 本书特点<a class="headerlink" href="#014" title="Permanent link">¶</a></h2>
|
||||
<p><strong>以实践为主</strong>。我们知道,学习英语期间光啃书本是远远不够的,需要多听、多说、多写,在实践中培养语感、积累经验。编程语言也是一门语言,因此学习方法也应是类似的,需要多看优秀代码、多敲键盘、多思考代码逻辑。</p>
|
||||
<p>本书的理论部分占少量篇幅,主要分为两类:一是基础且必要的概念知识,以培养读者对于算法的感性认识;二是重要的分类、对比或总结,这是为了帮助你站在更高视角俯瞰各个知识点,形成连点成面的效果。</p>
|
||||
<p>实践部分主要由示例和代码组成。代码配有简要注释,复杂示例会尽可能地使用视觉化的形式呈现。我强烈建议读者对照着代码自己敲一遍,如果时间有限,也至少逐行读、复制并运行一遍,配合着讲解将代码吃透。</p>
|
||||
@ -1887,8 +1751,7 @@
|
||||
<p><strong>内容精简化</strong>。大多数的经典教科书,会把每个主题都讲的很透彻。虽然透彻性正是其获得读者青睐的原因,但对于想要快速入门的初学者来说,这些教材的实用性不足。本书会避免引入非必要的概念、名词、定义等,也避免展开不必要的理论分析,毕竟这不是一本真正意义上的教材,主要任务是尽快地带领读者入门。</p>
|
||||
<p>引入一些生活案例或趣味内容,非常适合作为知识点的引子或者解释的补充,但当融入过多额外元素时,内容会稍显冗长,也许反而使读者容易迷失、抓不住重点,这也是本书需要避免的。</p>
|
||||
<p>敲代码如同写字,“美”是统一的追求。本书力求美观的代码,保证规范的变量命名、统一的空格与换行、对齐的缩进、整齐的注释等。</p>
|
||||
</details>
|
||||
<h2 id="016">0.1.6. 致谢<a class="headerlink" href="#016" title="Permanent link">¶</a></h2>
|
||||
<h2 id="015">0.1.5. 致谢<a class="headerlink" href="#015" title="Permanent link">¶</a></h2>
|
||||
<p>本书的成书过程中,我获得了许多人的帮助,包括但不限于:</p>
|
||||
<ul>
|
||||
<li>感谢我的女朋友泡泡担任本书的首位读者,从算法小白的视角为本书的写作提出了许多建议,使这本书更加适合算法初学者来阅读。</li>
|
||||
@ -1900,11 +1763,11 @@
|
||||
<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>
|
||||
<h2 id="017">0.1.7. 作者简介<a class="headerlink" href="#017" title="Permanent link">¶</a></h2>
|
||||
<h2 id="016">0.1.6. 作者简介<a class="headerlink" href="#016" title="Permanent link">¶</a></h2>
|
||||
<p><img alt="profile" class="center" src="../about_the_book.assets/profile.png" /></p>
|
||||
<h2 align="center"> Krahets </h2>
|
||||
<h2 align="center"> 靳宇栋(Krahets) </h2>
|
||||
|
||||
<h5 align="center"> 大厂高级算法工程师、算法爱好者 </h5>
|
||||
<h5 align="center"> 华为高级算法工程师、算法爱好者 </h5>
|
||||
|
||||
<p align="center"> 力扣(LeetCode)全网阅读量最高博主 </p>
|
||||
<p align="center"> 分享近百道算法题解,累积回复数千读者的问题 </p>
|
||||
|
@ -336,29 +336,43 @@
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#021" class="md-nav__link">
|
||||
0.2.1. 图文搭配学
|
||||
0.2.1. 行文风格约定
|
||||
</a>
|
||||
|
||||
</li>
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#022" class="md-nav__link">
|
||||
0.2.2. 代码实践学
|
||||
0.2.2. 在动画图解中高效学习
|
||||
</a>
|
||||
|
||||
<nav class="md-nav" aria-label="0.2.2. 代码实践学">
|
||||
</li>
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#023" class="md-nav__link">
|
||||
0.2.3. 在代码实践中加深理解
|
||||
</a>
|
||||
|
||||
<nav class="md-nav" aria-label="0.2.3. 在代码实践中加深理解">
|
||||
<ul class="md-nav__list">
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#_1" class="md-nav__link">
|
||||
下载代码仓
|
||||
<a href="#1" class="md-nav__link">
|
||||
1) 安装编程环境
|
||||
</a>
|
||||
|
||||
</li>
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#_2" class="md-nav__link">
|
||||
运行源代码
|
||||
<a href="#2" class="md-nav__link">
|
||||
2) 下载代码仓
|
||||
</a>
|
||||
|
||||
</li>
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#3" class="md-nav__link">
|
||||
3) 运行源代码
|
||||
</a>
|
||||
|
||||
</li>
|
||||
@ -366,18 +380,11 @@
|
||||
</ul>
|
||||
</nav>
|
||||
|
||||
</li>
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#023" class="md-nav__link">
|
||||
0.2.3. 提问讨论学
|
||||
</a>
|
||||
|
||||
</li>
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#024" class="md-nav__link">
|
||||
0.2.4. 算法学习“三步走”
|
||||
0.2.4. 在提问讨论中共同成长
|
||||
</a>
|
||||
|
||||
</li>
|
||||
@ -1569,29 +1576,43 @@
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#021" class="md-nav__link">
|
||||
0.2.1. 图文搭配学
|
||||
0.2.1. 行文风格约定
|
||||
</a>
|
||||
|
||||
</li>
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#022" class="md-nav__link">
|
||||
0.2.2. 代码实践学
|
||||
0.2.2. 在动画图解中高效学习
|
||||
</a>
|
||||
|
||||
<nav class="md-nav" aria-label="0.2.2. 代码实践学">
|
||||
</li>
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#023" class="md-nav__link">
|
||||
0.2.3. 在代码实践中加深理解
|
||||
</a>
|
||||
|
||||
<nav class="md-nav" aria-label="0.2.3. 在代码实践中加深理解">
|
||||
<ul class="md-nav__list">
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#_1" class="md-nav__link">
|
||||
下载代码仓
|
||||
<a href="#1" class="md-nav__link">
|
||||
1) 安装编程环境
|
||||
</a>
|
||||
|
||||
</li>
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#_2" class="md-nav__link">
|
||||
运行源代码
|
||||
<a href="#2" class="md-nav__link">
|
||||
2) 下载代码仓
|
||||
</a>
|
||||
|
||||
</li>
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#3" class="md-nav__link">
|
||||
3) 运行源代码
|
||||
</a>
|
||||
|
||||
</li>
|
||||
@ -1599,18 +1620,11 @@
|
||||
</ul>
|
||||
</nav>
|
||||
|
||||
</li>
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#023" class="md-nav__link">
|
||||
0.2.3. 提问讨论学
|
||||
</a>
|
||||
|
||||
</li>
|
||||
|
||||
<li class="md-nav__item">
|
||||
<a href="#024" class="md-nav__link">
|
||||
0.2.4. 算法学习“三步走”
|
||||
0.2.4. 在提问讨论中共同成长
|
||||
</a>
|
||||
|
||||
</li>
|
||||
@ -1640,39 +1654,152 @@
|
||||
|
||||
|
||||
<h1 id="02">0.2. 如何使用本书<a class="headerlink" href="#02" title="Permanent link">¶</a></h1>
|
||||
<h2 id="021">0.2.1. 图文搭配学<a class="headerlink" href="#021" title="Permanent link">¶</a></h2>
|
||||
<p>视频和图片相比于文字的信息密度和结构化程度更高,更容易让人理解。在本书中,重点和难点知识会主要以动画、图解的形式呈现,而文字的作用则是作为动画和图的解释与补充。</p>
|
||||
<p>在阅读本书的过程中,若发现某段内容提供了动画或图解,<strong>建议你以图为主线</strong>,将文字内容(一般在图的上方)对齐到图中内容,综合来理解。</p>
|
||||
<p><img alt="animation" src="../suggestions.assets/animation.gif" /></p>
|
||||
<h2 id="022">0.2.2. 代码实践学<a class="headerlink" href="#022" title="Permanent link">¶</a></h2>
|
||||
<div class="admonition tip">
|
||||
<p class="admonition-title">前置工作</p>
|
||||
<p>如果没有本地编程环境,可以参照下节 <a href="https://www.hello-algo.com/chapter_preface/installation/">编程环境安装</a> 。</p>
|
||||
<p><strong>强烈建议通读本节内容,以获取最佳学习体验</strong>。</p>
|
||||
<h2 id="021">0.2.1. 行文风格约定<a class="headerlink" href="#021" title="Permanent link">¶</a></h2>
|
||||
<p>标题后标注 <code>*</code> 的是选读章节,内容相对较难。如果你的时间有限,建议可以先跳过。</p>
|
||||
<p>文章中的重要名词会用 <code>「」</code> 括号标注,例如 <code>「数组 Array」</code> 。建议记住这些名词,包括英文翻译,以便后续阅读文献时使用。</p>
|
||||
<p>重点内容、总起句、总结句会被 <strong>加粗</strong> ,此类文字值得特别关注。</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">
|
||||
<div class="tabbed-block">
|
||||
<div class="highlight"><pre><span></span><code><a id="__codelineno-0-1" name="__codelineno-0-1" href="#__codelineno-0-1"></a><span class="cm">/* 标题注释,用于标注函数、类、测试样例等 */</span>
|
||||
<a id="__codelineno-0-2" name="__codelineno-0-2" href="#__codelineno-0-2"></a>
|
||||
<a id="__codelineno-0-3" name="__codelineno-0-3" href="#__codelineno-0-3"></a><span class="c1">// 内容注释,用于详解代码</span>
|
||||
<a id="__codelineno-0-4" name="__codelineno-0-4" href="#__codelineno-0-4"></a>
|
||||
<a id="__codelineno-0-5" name="__codelineno-0-5" href="#__codelineno-0-5"></a><span class="cm">/**</span>
|
||||
<a id="__codelineno-0-6" name="__codelineno-0-6" href="#__codelineno-0-6"></a><span class="cm"> * 多行</span>
|
||||
<a id="__codelineno-0-7" name="__codelineno-0-7" href="#__codelineno-0-7"></a><span class="cm"> * 注释</span>
|
||||
<a id="__codelineno-0-8" name="__codelineno-0-8" href="#__codelineno-0-8"></a><span class="cm"> */</span>
|
||||
</code></pre></div>
|
||||
</div>
|
||||
<h3 id="_1">下载代码仓<a class="headerlink" href="#_1" title="Permanent link">¶</a></h3>
|
||||
<div class="tabbed-block">
|
||||
<div class="highlight"><pre><span></span><code><a id="__codelineno-1-1" name="__codelineno-1-1" href="#__codelineno-1-1"></a><span class="cm">/* 标题注释,用于标注函数、类、测试样例等 */</span>
|
||||
<a id="__codelineno-1-2" name="__codelineno-1-2" href="#__codelineno-1-2"></a>
|
||||
<a id="__codelineno-1-3" name="__codelineno-1-3" href="#__codelineno-1-3"></a><span class="c1">// 内容注释,用于详解代码</span>
|
||||
<a id="__codelineno-1-4" name="__codelineno-1-4" href="#__codelineno-1-4"></a>
|
||||
<a id="__codelineno-1-5" name="__codelineno-1-5" href="#__codelineno-1-5"></a><span class="cm">/**</span>
|
||||
<a id="__codelineno-1-6" name="__codelineno-1-6" href="#__codelineno-1-6"></a><span class="cm"> * 多行</span>
|
||||
<a id="__codelineno-1-7" name="__codelineno-1-7" href="#__codelineno-1-7"></a><span class="cm"> * 注释</span>
|
||||
<a id="__codelineno-1-8" name="__codelineno-1-8" href="#__codelineno-1-8"></a><span class="cm"> */</span>
|
||||
</code></pre></div>
|
||||
</div>
|
||||
<div class="tabbed-block">
|
||||
<div class="highlight"><pre><span></span><code><a id="__codelineno-2-1" name="__codelineno-2-1" href="#__codelineno-2-1"></a><span class="sd">""" 标题注释,用于标注函数、类、测试样例等 """</span>
|
||||
<a id="__codelineno-2-2" name="__codelineno-2-2" href="#__codelineno-2-2"></a>
|
||||
<a id="__codelineno-2-3" name="__codelineno-2-3" href="#__codelineno-2-3"></a><span class="c1"># 内容注释,用于详解代码</span>
|
||||
<a id="__codelineno-2-4" name="__codelineno-2-4" href="#__codelineno-2-4"></a>
|
||||
<a id="__codelineno-2-5" name="__codelineno-2-5" href="#__codelineno-2-5"></a><span class="sd">"""</span>
|
||||
<a id="__codelineno-2-6" name="__codelineno-2-6" href="#__codelineno-2-6"></a><span class="sd">多行</span>
|
||||
<a id="__codelineno-2-7" name="__codelineno-2-7" href="#__codelineno-2-7"></a><span class="sd">注释</span>
|
||||
<a id="__codelineno-2-8" name="__codelineno-2-8" href="#__codelineno-2-8"></a><span class="sd">"""</span>
|
||||
</code></pre></div>
|
||||
</div>
|
||||
<div class="tabbed-block">
|
||||
<div class="highlight"><pre><span></span><code><a id="__codelineno-3-1" name="__codelineno-3-1" href="#__codelineno-3-1"></a><span class="cm">/* 标题注释,用于标注函数、类、测试样例等 */</span>
|
||||
<a id="__codelineno-3-2" name="__codelineno-3-2" href="#__codelineno-3-2"></a>
|
||||
<a id="__codelineno-3-3" name="__codelineno-3-3" href="#__codelineno-3-3"></a><span class="c1">// 内容注释,用于详解代码</span>
|
||||
<a id="__codelineno-3-4" name="__codelineno-3-4" href="#__codelineno-3-4"></a>
|
||||
<a id="__codelineno-3-5" name="__codelineno-3-5" href="#__codelineno-3-5"></a><span class="cm">/**</span>
|
||||
<a id="__codelineno-3-6" name="__codelineno-3-6" href="#__codelineno-3-6"></a><span class="cm"> * 多行</span>
|
||||
<a id="__codelineno-3-7" name="__codelineno-3-7" href="#__codelineno-3-7"></a><span class="cm"> * 注释</span>
|
||||
<a id="__codelineno-3-8" name="__codelineno-3-8" href="#__codelineno-3-8"></a><span class="cm"> */</span>
|
||||
</code></pre></div>
|
||||
</div>
|
||||
<div class="tabbed-block">
|
||||
<div class="highlight"><pre><span></span><code><a id="__codelineno-4-1" name="__codelineno-4-1" href="#__codelineno-4-1"></a><span class="cm">/* 标题注释,用于标注函数、类、测试样例等 */</span>
|
||||
<a id="__codelineno-4-2" name="__codelineno-4-2" href="#__codelineno-4-2"></a>
|
||||
<a id="__codelineno-4-3" name="__codelineno-4-3" href="#__codelineno-4-3"></a><span class="c1">// 内容注释,用于详解代码</span>
|
||||
<a id="__codelineno-4-4" name="__codelineno-4-4" href="#__codelineno-4-4"></a>
|
||||
<a id="__codelineno-4-5" name="__codelineno-4-5" href="#__codelineno-4-5"></a><span class="cm">/**</span>
|
||||
<a id="__codelineno-4-6" name="__codelineno-4-6" href="#__codelineno-4-6"></a><span class="cm"> * 多行</span>
|
||||
<a id="__codelineno-4-7" name="__codelineno-4-7" href="#__codelineno-4-7"></a><span class="cm"> * 注释</span>
|
||||
<a id="__codelineno-4-8" name="__codelineno-4-8" href="#__codelineno-4-8"></a><span class="cm"> */</span>
|
||||
</code></pre></div>
|
||||
</div>
|
||||
<div class="tabbed-block">
|
||||
<div class="highlight"><pre><span></span><code><a id="__codelineno-5-1" name="__codelineno-5-1" href="#__codelineno-5-1"></a><span class="cm">/* 标题注释,用于标注函数、类、测试样例等 */</span>
|
||||
<a id="__codelineno-5-2" name="__codelineno-5-2" href="#__codelineno-5-2"></a>
|
||||
<a id="__codelineno-5-3" name="__codelineno-5-3" href="#__codelineno-5-3"></a><span class="c1">// 内容注释,用于详解代码</span>
|
||||
<a id="__codelineno-5-4" name="__codelineno-5-4" href="#__codelineno-5-4"></a>
|
||||
<a id="__codelineno-5-5" name="__codelineno-5-5" href="#__codelineno-5-5"></a><span class="cm">/**</span>
|
||||
<a id="__codelineno-5-6" name="__codelineno-5-6" href="#__codelineno-5-6"></a><span class="cm"> * 多行</span>
|
||||
<a id="__codelineno-5-7" name="__codelineno-5-7" href="#__codelineno-5-7"></a><span class="cm"> * 注释</span>
|
||||
<a id="__codelineno-5-8" name="__codelineno-5-8" href="#__codelineno-5-8"></a><span class="cm"> */</span>
|
||||
</code></pre></div>
|
||||
</div>
|
||||
<div class="tabbed-block">
|
||||
<div class="highlight"><pre><span></span><code><a id="__codelineno-6-1" name="__codelineno-6-1" href="#__codelineno-6-1"></a><span class="cm">/* 标题注释,用于标注函数、类、测试样例等 */</span>
|
||||
<a id="__codelineno-6-2" name="__codelineno-6-2" href="#__codelineno-6-2"></a>
|
||||
<a id="__codelineno-6-3" name="__codelineno-6-3" href="#__codelineno-6-3"></a><span class="c1">// 内容注释,用于详解代码</span>
|
||||
<a id="__codelineno-6-4" name="__codelineno-6-4" href="#__codelineno-6-4"></a>
|
||||
<a id="__codelineno-6-5" name="__codelineno-6-5" href="#__codelineno-6-5"></a><span class="cm">/**</span>
|
||||
<a id="__codelineno-6-6" name="__codelineno-6-6" href="#__codelineno-6-6"></a><span class="cm"> * 多行</span>
|
||||
<a id="__codelineno-6-7" name="__codelineno-6-7" href="#__codelineno-6-7"></a><span class="cm"> * 注释</span>
|
||||
<a id="__codelineno-6-8" name="__codelineno-6-8" href="#__codelineno-6-8"></a><span class="cm"> */</span>
|
||||
</code></pre></div>
|
||||
</div>
|
||||
<div class="tabbed-block">
|
||||
<div class="highlight"><pre><span></span><code><a id="__codelineno-7-1" name="__codelineno-7-1" href="#__codelineno-7-1"></a><span class="cm">/* 标题注释,用于标注函数、类、测试样例等 */</span>
|
||||
<a id="__codelineno-7-2" name="__codelineno-7-2" href="#__codelineno-7-2"></a>
|
||||
<a id="__codelineno-7-3" name="__codelineno-7-3" href="#__codelineno-7-3"></a><span class="c1">// 内容注释,用于详解代码</span>
|
||||
<a id="__codelineno-7-4" name="__codelineno-7-4" href="#__codelineno-7-4"></a>
|
||||
<a id="__codelineno-7-5" name="__codelineno-7-5" href="#__codelineno-7-5"></a><span class="cm">/**</span>
|
||||
<a id="__codelineno-7-6" name="__codelineno-7-6" href="#__codelineno-7-6"></a><span class="cm"> * 多行</span>
|
||||
<a id="__codelineno-7-7" name="__codelineno-7-7" href="#__codelineno-7-7"></a><span class="cm"> * 注释</span>
|
||||
<a id="__codelineno-7-8" name="__codelineno-7-8" href="#__codelineno-7-8"></a><span class="cm"> */</span>
|
||||
</code></pre></div>
|
||||
</div>
|
||||
<div class="tabbed-block">
|
||||
<div class="highlight"><pre><span></span><code><a id="__codelineno-8-1" name="__codelineno-8-1" href="#__codelineno-8-1"></a><span class="cm">/* 标题注释,用于标注函数、类、测试样例等 */</span>
|
||||
<a id="__codelineno-8-2" name="__codelineno-8-2" href="#__codelineno-8-2"></a>
|
||||
<a id="__codelineno-8-3" name="__codelineno-8-3" href="#__codelineno-8-3"></a><span class="c1">// 内容注释,用于详解代码</span>
|
||||
<a id="__codelineno-8-4" name="__codelineno-8-4" href="#__codelineno-8-4"></a>
|
||||
<a id="__codelineno-8-5" name="__codelineno-8-5" href="#__codelineno-8-5"></a><span class="cm">/**</span>
|
||||
<a id="__codelineno-8-6" name="__codelineno-8-6" href="#__codelineno-8-6"></a><span class="cm"> * 多行</span>
|
||||
<a id="__codelineno-8-7" name="__codelineno-8-7" href="#__codelineno-8-7"></a><span class="cm"> * 注释</span>
|
||||
<a id="__codelineno-8-8" name="__codelineno-8-8" href="#__codelineno-8-8"></a><span class="cm"> */</span>
|
||||
</code></pre></div>
|
||||
</div>
|
||||
<div class="tabbed-block">
|
||||
<div class="highlight"><pre><span></span><code><a id="__codelineno-9-1" name="__codelineno-9-1" href="#__codelineno-9-1"></a><span class="c1">// 标题注释,用于标注函数、类、测试样例等</span>
|
||||
<a id="__codelineno-9-2" name="__codelineno-9-2" href="#__codelineno-9-2"></a>
|
||||
<a id="__codelineno-9-3" name="__codelineno-9-3" href="#__codelineno-9-3"></a><span class="c1">// 内容注释,用于详解代码</span>
|
||||
<a id="__codelineno-9-4" name="__codelineno-9-4" href="#__codelineno-9-4"></a>
|
||||
<a id="__codelineno-9-5" name="__codelineno-9-5" href="#__codelineno-9-5"></a><span class="c1">// 多行</span>
|
||||
<a id="__codelineno-9-6" name="__codelineno-9-6" href="#__codelineno-9-6"></a><span class="c1">// 注释</span>
|
||||
</code></pre></div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<h2 id="022">0.2.2. 在动画图解中高效学习<a class="headerlink" href="#022" title="Permanent link">¶</a></h2>
|
||||
<p>视频和图片相比于文字的信息密度和结构化程度更高,更容易理解。在本书中,<strong>知识重难点会主要以动画、图解的形式呈现</strong>,而文字的作用则是作为动画和图的解释与补充。</p>
|
||||
<p>阅读本书时,若发现某段内容提供了动画或图解,<strong>建议你以图为主线</strong>,将文字内容(一般在图的上方)对齐到图中内容,综合来理解。</p>
|
||||
<p><img alt="animation" src="../suggestions.assets/animation.gif" /></p>
|
||||
<h2 id="023">0.2.3. 在代码实践中加深理解<a class="headerlink" href="#023" title="Permanent link">¶</a></h2>
|
||||
<p>本书的配套代码托管在<a href="https://github.com/krahets/hello-algo">GitHub 仓库</a>,<strong>源代码包含详细注释,配有测试样例,可以直接运行</strong>。</p>
|
||||
<ul>
|
||||
<li>若学习时间紧张,<strong>建议至少将所有代码通读并运行一遍</strong>。</li>
|
||||
<li>若时间允许,<strong>强烈建议对照着代码自己敲一遍</strong>。相比于读代码,写代码的过程往往能带来新的收获。</li>
|
||||
</ul>
|
||||
<h3 id="1">1) 安装编程环境<a class="headerlink" href="#1" title="Permanent link">¶</a></h3>
|
||||
<p>如果没有本地编程环境,可以参照<a href="https://www.hello-algo.com/chapter_preface/installation/">下节</a>。</p>
|
||||
<h3 id="2">2) 下载代码仓<a class="headerlink" href="#2" title="Permanent link">¶</a></h3>
|
||||
<p>如果已经安装 <a href="https://git-scm.com/downloads">Git</a> ,可以通过命令行来克隆代码仓。</p>
|
||||
<div class="highlight"><pre><span></span><code><a id="__codelineno-0-1" name="__codelineno-0-1" href="#__codelineno-0-1"></a>git<span class="w"> </span>clone<span class="w"> </span>https://github.com/krahets/hello-algo.git
|
||||
<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>
|
||||
<h3 id="_2">运行源代码<a class="headerlink" href="#_2" title="Permanent link">¶</a></h3>
|
||||
<p>本书提供配套 Java, C++, Python 代码仓(后续可能拓展支持语言)。书中的代码栏上若标有 <code>*.java</code> , <code>*.cpp</code> , <code>*.py</code> ,则可在仓库 codes 文件夹中找到对应的 <strong>代码源文件</strong>。</p>
|
||||
<h3 id="3">3) 运行源代码<a class="headerlink" href="#3" title="Permanent link">¶</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>这些源文件中包含详细注释,配有测试样例,可以直接运行,帮助你省去不必要的调试时间,可以将精力集中在学习内容上。</p>
|
||||
<p>源代码文件可以帮助你省去不必要的调试时间,将精力集中在学习内容上。</p>
|
||||
<p><img alt="running_code" src="../suggestions.assets/running_code.gif" /></p>
|
||||
<div class="admonition tip">
|
||||
<p class="admonition-title">代码学习建议</p>
|
||||
<p>若学习时间紧张,<strong>请至少将所有代码通读并运行一遍</strong>。若时间允许,<strong>强烈建议对照着代码自己敲一遍</strong>,逐渐锻炼肌肉记忆。相比于读代码,写代码的过程往往能带来新的收获。</p>
|
||||
</div>
|
||||
<h2 id="023">0.2.3. 提问讨论学<a class="headerlink" href="#023" title="Permanent link">¶</a></h2>
|
||||
<p>阅读本书时,请不要“惯着”那些弄不明白的知识点。如果有任何疑惑,<strong>可以在评论区留下你的问题</strong>,小伙伴们和我都会给予解答(您一般 3 天内会得到回复)。</p>
|
||||
<p>同时,也希望你可以多花时间逛逛评论区。一方面,可以看看大家遇到了什么问题,反过来查漏补缺,这往往可以引起更加深度的思考。另一方面,也希望你可以慷慨地解答小伙伴们的问题、分享自己的见解,大家一起加油与进步!</p>
|
||||
<h2 id="024">0.2.4. 在提问讨论中共同成长<a class="headerlink" href="#024" title="Permanent link">¶</a></h2>
|
||||
<p>阅读本书时,请不要“惯着”那些弄不明白的知识点。<strong>欢迎在评论区留下你的问题</strong>,小伙伴们和我都会给予解答,您一般 2 日内会得到回复。</p>
|
||||
<p>同时,也希望你可以多花时间逛逛评论区。一方面,可以看看大家遇到了什么问题,反过来查漏补缺,这往往可以引起更加深度的思考。另一方面,也希望你可以慷慨地解答小伙伴们的问题、分享自己的见解,大家互相学习与进步!</p>
|
||||
<p><img alt="comment" src="../suggestions.assets/comment.gif" /></p>
|
||||
<h2 id="024">0.2.4. 算法学习“三步走”<a class="headerlink" href="#024" title="Permanent link">¶</a></h2>
|
||||
<p><strong>第一阶段,算法入门,也正是本书的定位</strong>。熟悉各种数据结构的特点、用法,学习各种算法的工作原理、用途、效率等。</p>
|
||||
<p><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 道题量,熟悉大多数的算法问题。刚开始刷题时,“遗忘”是最大的困扰点,但这是很正常的,请不要担心。学习中有一种概念叫“周期性回顾”,同一道题隔段时间做一次,当做了三遍以上,往往就能牢记于心了。</p>
|
||||
<p><strong>第三阶段,搭建知识体系</strong>。在学习方面,可以阅读算法专栏文章、解题框架、算法教材,不断地丰富知识体系。在刷题方面,可以开始采用进阶刷题方案,例如按专题分类、一题多解、一解多题等,刷题方案在社区中可以找到一些讲解,在此不做赘述。</p>
|
||||
<p><img alt="learning_route" src="../suggestions.assets/learning_route.png" /></p>
|
||||
|
||||
|
||||
|
||||
|
@ -1549,7 +1549,8 @@
|
||||
<p>“一本通俗易懂的数据结构与算法入门书,引导读者手脑并用地学习,强烈推荐算法初学者阅读。”</p>
|
||||
<p><strong>—— 邓俊辉,清华大学计算机系教授</strong></p>
|
||||
</div>
|
||||
<h2 align="center"> 参与写作 </h2>
|
||||
<hr />
|
||||
<h2 align="center"> 致谢 </h2>
|
||||
|
||||
<p>感谢本开源书的每一位撰稿人,是他们的无私奉献让这本书变得更好,他们是(顺序由 contrib.rocks 自动生成):</p>
|
||||
<p align="center">
|
||||
|
File diff suppressed because one or more lines are too long
BIN
sitemap.xml.gz
BIN
sitemap.xml.gz
Binary file not shown.
Reference in New Issue
Block a user