This commit is contained in:
krahets
2023-12-02 06:24:11 +08:00
parent 5783c402bf
commit d20d8b3ee1
107 changed files with 1685 additions and 1745 deletions

View File

@ -3426,15 +3426,15 @@
<h1 id="02">0.2 &nbsp; 如何使用本书<a class="headerlink" href="#02" title="Permanent link">&para;</a></h1>
<div class="admonition tip">
<p class="admonition-title">Tip</p>
<p>为了获得最佳的阅读体验,建议通读本节内容。</p>
<p>为了获得最佳的阅读体验,建议通读本节内容。</p>
</div>
<h2 id="021">0.2.1 &nbsp; 行文风格约定<a class="headerlink" href="#021" title="Permanent link">&para;</a></h2>
<ul>
<li>标题后标注 <code>*</code> 的是选读章节,内容相对困难。如果你的时间有限,建议可以先跳过。</li>
<li>专有名词和有特指含义的词句会使用 <code>“双引号”</code> 标注,以避免歧义。</li>
<li>标题后标注 <code>*</code> 的是选读章节,内容相对困难。如果你的时间有限,可以先跳过。</li>
<li>重要专有名词及其英文翻译会用 <code>「 」</code> 括号标注,例如 <code>「数组 array」</code> 。建议记住它们,以便阅读文献。</li>
<li><strong>加粗的文字</strong> 表示重点内容或总结性语句,这类文字值得特别关注</li>
<li>当涉及到编程语言之间不一致的名词时,本书均以 Python 为准,例如使用 <span class="arithmatex">\(\text{None}\)</span> 来表示“空”</li>
<li>专有名词和有特指含义的词句会使用 <code>“引号”</code> 标注,以避免歧义</li>
<li>重要名词、重点内容和总结性语句会被 <strong>加粗</strong> ,这类文字值得特别关注</li>
<li>当涉及编程语言之间不一致的名词时,本书均以 Python 为准,例如使用 <span class="arithmatex">\(\text{None}\)</span> 来表示“空”。</li>
<li>本书部分放弃了编程语言的注释规范,以换取更加紧凑的内容排版。注释主要分为三种类型:标题注释、内容注释、多行注释。</li>
</ul>
<div class="tabbed-set tabbed-alternate" data-tabs="1:12"><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" /><input id="__tabbed_1_11" name="__tabbed_1" type="radio" /><input id="__tabbed_1_12" name="__tabbed_1" type="radio" /><div class="tabbed-labels"><label for="__tabbed_1_1">Python</label><label for="__tabbed_1_2">C++</label><label for="__tabbed_1_3">Java</label><label for="__tabbed_1_4">C#</label><label for="__tabbed_1_5">Go</label><label for="__tabbed_1_6">Swift</label><label for="__tabbed_1_7">JS</label><label for="__tabbed_1_8">TS</label><label for="__tabbed_1_9">Dart</label><label for="__tabbed_1_10">Rust</label><label for="__tabbed_1_11">C</label><label for="__tabbed_1_12">Zig</label></div>
@ -3573,23 +3573,24 @@
</div>
<h2 id="022">0.2.2 &nbsp; 在动画图解中高效学习<a class="headerlink" href="#022" title="Permanent link">&para;</a></h2>
<p>相较于文字,视频和图片具有更高的信息密度和结构化程度,更易于理解。在本书中,<strong>重点和难点知识将主要通过动画和图解形式展示</strong>,而文字则作为动画和图片的解释与补充。</p>
<p>如果你在阅读本书时,发现某段内容提供了图 0-2 所示的动画或图解,<strong>请以图为主、以文字为辅</strong>,综合两者来理解内容。</p>
<p>如果你在阅读本书时,发现某段内容提供了图 0-2 所示的动画或图解,<strong>请以图为主、以文字为辅</strong>,综合两者来理解内容。</p>
<p><a class="glightbox" href="../../index.assets/animation.gif" data-type="image" data-width="100%" data-height="auto" data-desc-position="bottom"><img alt="动画图解示例" class="animation-figure" src="../../index.assets/animation.gif" /></a></p>
<p align="center"> 图 0-2 &nbsp; 动画图解示例 </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>。如图 0-3 所示,<strong>源代码附有测试样例,可一键运行</strong></p>
<p>本书的配套代码托管在 <a href="https://github.com/krahets/hello-algo">GitHub 仓库</a>。如图 0-3 所示,<strong>源代码附有测试样例,可一键运行</strong></p>
<p>如果时间允许,<strong>建议你参照代码自行敲一遍</strong>。如果学习时间有限,请至少通读并运行所有代码。</p>
<p>与阅读代码相比,编写代码的过程往往能带来更多收获。<strong>动手学,才是真的学</strong></p>
<p><a class="glightbox" href="../../index.assets/running_code.gif" data-type="image" data-width="100%" data-height="auto" data-desc-position="bottom"><img alt="运行代码示例" class="animation-figure" src="../../index.assets/running_code.gif" /></a></p>
<p align="center"> 图 0-3 &nbsp; 运行代码示例 </p>
<p>运行代码的前置工作主要分为三步。</p>
<p><strong>第一步:安装本地编程环境</strong>。请参照<a href="https://www.hello-algo.com/chapter_appendix/installation/">附录教程</a>进行安装,如果已安装则可跳过此步骤。</p>
<p><strong>第二步:克隆或下载代码仓</strong>如果已经安装 <a href="https://git-scm.com/downloads">Git</a> ,可以通过以下命令克隆本仓库</p>
<p><strong>第一步:安装本地编程环境</strong>。请参照附录所示的<a href="https://www.hello-algo.com/chapter_appendix/installation/">教程</a>进行安装,如果已安装则可跳过此步骤。</p>
<p><strong>第二步:克隆或下载代码仓</strong>前往 <a href="https://github.com/krahets/hello-algo">GitHub 仓库</a></p>
<p>如果已经安装 <a href="https://git-scm.com/downloads">Git</a> ,可以通过以下命令克隆本仓库:</p>
<div class="highlight"><pre><span></span><code><a id="__codelineno-12-1" name="__codelineno-12-1" href="#__codelineno-12-1"></a>git<span class="w"> </span>clone<span class="w"> </span>https://github.com/krahets/hello-algo.git
</code></pre></div>
<p>当然,你也可以在图 0-4 所示的位置点击“Download ZIP”直接下载代码压缩包然后在本地解压即可。</p>
<p>当然,你也可以在图 0-4 所示的位置点击“Download ZIP”按钮直接下载代码压缩包,然后在本地解压即可。</p>
<p><a class="glightbox" href="../suggestions.assets/download_code.png" data-type="image" data-width="100%" data-height="auto" data-desc-position="bottom"><img alt="克隆仓库与下载代码" class="animation-figure" src="../suggestions.assets/download_code.png" /></a></p>
<p align="center"> 图 0-4 &nbsp; 克隆仓库与下载代码 </p>
@ -3599,18 +3600,18 @@
<h2 id="024">0.2.4 &nbsp; 在提问讨论中共同成长<a class="headerlink" href="#024" title="Permanent link">&para;</a></h2>
<p>在阅读本书时,请不要轻易跳过那些没学明白的知识点。<strong>欢迎在评论区提出你的问题</strong>,我和小伙伴们将竭诚为你解答,一般情况下可在两天内回复。</p>
<p>如图 0-6 所示,每篇文章的底部都配有评论区。希望你能多关注评论区的内容。一方面,你可以了解大家遇到的问题,从而查漏补缺,激发更深入的思考。另一方面,期待你能慷慨地回答其他小伙伴的问题,分享的见解,帮助他人进步。</p>
<p>如图 0-6 所示,每个章节的底部都配有评论区。希望你能多关注评论区的内容。一方面,你可以了解大家遇到的问题,从而查漏补缺,激发更深入的思考。另一方面,期待你能慷慨地回答其他小伙伴的问题,分享的见解,帮助他人进步。</p>
<p><a class="glightbox" href="../../index.assets/comment.gif" data-type="image" data-width="100%" data-height="auto" data-desc-position="bottom"><img alt="评论区示例" class="animation-figure" src="../../index.assets/comment.gif" /></a></p>
<p align="center"> 图 0-6 &nbsp; 评论区示例 </p>
<h2 id="025">0.2.5 &nbsp; 算法学习路线<a class="headerlink" href="#025" title="Permanent link">&para;</a></h2>
<p>从总体上看,我们可以将学习数据结构与算法的过程划分为三个阶段。</p>
<ol>
<li><strong>算法入门</strong>。我们需要熟悉各种数据结构的特点和用法,学习不同算法的原理、流程、用途和效率等方面内容。</li>
<li><strong>刷算法题</strong>。建议从热门题目开刷,如<a href="https://leetcode.cn/studyplan/coding-interviews/">剑指 Offer</a><a href="https://leetcode.cn/studyplan/top-100-liked/">LeetCode Hot 100</a>,先积累至少 100 道题目,熟悉主流的算法问题。初次刷题时,“知识遗忘”可能是一个挑战,但请放心,这是很正常的。我们可以按照“艾宾浩斯遗忘曲线”来复习题目,通常在进行 3-5 轮的重复后,就能将其牢记在心。</li>
<li><strong>搭建知识体系</strong>。在学习方面,我们可以阅读算法专栏文章、解题框架和算法教材,以不断丰富知识体系。在刷题方面,可以尝试采用进阶刷题策略,如按专题分类、一题多解、一解多题等,相关的刷题心得可以在各个社区找到。</li>
<li><strong>阶段一:算法入门</strong>。我们需要熟悉各种数据结构的特点和用法,学习不同算法的原理、流程、用途和效率等方面内容。</li>
<li><strong>阶段二:刷算法题</strong>。建议从热门题目开刷,如<a href="https://leetcode.cn/studyplan/coding-interviews/">剑指 Offer</a>”和“<a href="https://leetcode.cn/studyplan/top-100-liked/">LeetCode Hot 100</a>,先积累至少 100 道题目,熟悉主流的算法问题。初次刷题时,“知识遗忘”可能是一个挑战,但请放心,这是很正常的。我们可以按照“艾宾浩斯遗忘曲线”来复习题目,通常在进行 35 轮的重复后,就能将其牢记在心。</li>
<li><strong>阶段三:搭建知识体系</strong>。在学习方面,我们可以阅读算法专栏文章、解题框架和算法教材,以不断丰富知识体系。在刷题方面,可以尝试采用进阶刷题策略,如按专题分类、一题多解、一解多题等,相关的刷题心得可以在各个社区找到。</li>
</ol>
<p>如图 0-7 所示,本书内容主要涵盖“第一阶段”,旨在帮助你更高效地展开第二和第三阶段的学习。</p>
<p>如图 0-7 所示,本书内容主要涵盖“阶段”,旨在帮助你更高效地展开阶段二和阶段的学习。</p>
<p><a class="glightbox" href="../suggestions.assets/learning_route.png" data-type="image" data-width="100%" data-height="auto" data-desc-position="bottom"><img alt="算法学习路线" class="animation-figure" src="../suggestions.assets/learning_route.png" /></a></p>
<p align="center"> 图 0-7 &nbsp; 算法学习路线 </p>