Polish the chapter of heap, introduction, preface.

Replace "其它" with "其他"
This commit is contained in:
krahets
2023-04-09 19:12:37 +08:00
parent 10e2180013
commit 0bec52d7cc
29 changed files with 185 additions and 161 deletions

View File

@@ -1,18 +1,18 @@
# 关于本书
本项目致力于构建一本开源免费、新手友好的数据结构与算法入门
本项目旨在创建一本开源免费、新手友好的数据结构与算法入门教程
- 全书采用动画图解,结构化地讲解数据结构与算法知识,内容清晰易懂、学习曲线平滑;
- 算法源代码皆可一键运行,支持 Java, C++, Python, Go, JS, TS, C#, Swift, Zig 等语言;
- 鼓励读者在章节讨论区互帮互助、共同进步,提问与评论一般能在两日内得到回复;
- 鼓励读者在章节讨论区互帮互助、共同进步,提问与评论通常可在两日内得到回复;
## 读者对象
如果您是「算法初学者」,完全没有接触过算法,或者已经有少量刷题,对数据结构与算法有朦胧的理解,在会与不会之间反复横跳,那么这本书是为你而写
您是「算法初学者」,从未接触过算法,或者已经有一些刷题经验,对数据结构与算法有模糊的认识,在会与不会之间反复横跳,那么这本书是为您量身定制
如果您是「算法老手」,已经积累一定刷题量,接触过大多数题型,那么本书可以帮助你回顾与梳理算法知识体系,仓库源代码可以被当作“刷题工具库”或“算法字典”来使用。
如果您是「算法老手」,已经积累一定刷题量,熟悉大部分题型,那么本书可助您回顾与梳理算法知识体系,仓库源代码可以被当作“刷题工具库”或“算法字典”来使用。
如果您是「算法大佬」,希望可以得到你的宝贵意见建议,或者[一起参与创作](https://www.hello-algo.com/chapter_appendix/contribution/)。
您是「算法专家」,我们期待收到您的宝贵建议,或者[一起参与创作](https://www.hello-algo.com/chapter_appendix/contribution/)。
!!! success "前置条件"
@@ -20,26 +20,26 @@
## 内容结构
本书主要内容
本书主要内容包括
- **复杂度分析**:数据结构与算法的评价维度、算法效率的评估方法。时间复杂度、空间复杂度,包括推算方法、常见类型、示例等。
- **数据结构**:常用的基本数据类型,数据在内存中的存储式、数据结构分类方法。数组、链表、栈、队列、散列表、树、堆、图等数据结构,内容包括定义、优劣势、常用操作、常见类型、典型应用、实现方法等。
- **算法**:查找算法、排序算法、搜索与回溯、动态规划、分治算法,内容包括定义、使用场景、优劣势、时空效率、实现方法、示例题目等。
- **数据结构**:常基本数据类型,数据在内存中的存储式、数据结构分类方法。涉及数组、链表、栈、队列、散列表、树、堆、图等数据结构,内容包括定义、优缺点、常用操作、常见类型、典型应用、实现方法等。
- **算法**:查找算法、排序算法、搜索与回溯、动态规划、分治算法,内容涵盖定义、用场景、优缺点、时空效率、实现方法、示例题目等。
![Hello 算法内容结构](about_the_book.assets/hello_algo_mindmap.png)
## 致谢
本书的成书过程中,我得了许多人的帮助,包括但不限于:
本书的创作过程中,我得了许多人的帮助,包括但不限于:
- 感谢我在公司的导师李汐博士,在一次畅谈时您告诉我“觉得应该做就去做”,坚定了我写这本书的决心。
- 感谢我的女朋友泡泡担任本书的首位读者,从算法小白的角提出许多建议,使本书更适合初学者来阅读。
- 感谢腾宝、琦宝、飞宝为本书起了个好听又有梗名字,直接唤起我最初敲下第一行代码 "Hello World!" 的回忆。
- 感谢苏潼为本书设计了封面和 LOGO ,在我的强迫症下前后多次帮忙修改,谢谢你的耐心
- 感谢 @squidfunk 给出的写作排版建议,以及优秀开源项目 [Material-for-MkDocs](https://github.com/squidfunk/mkdocs-material/tree/master) 。
- 感谢我在公司的导师李汐博士,在深入交谈中您鼓励我“行动起来”,坚定了我写这本书的决心。
- 感谢我的女朋友泡泡作为本书的首位读者,从算法小白的角提出许多宝贵建议,使本书更适合新手阅读。
- 感谢腾宝、琦宝、飞宝为本书起了一个富有创意的名字,唤起大家写下第一行代码 "Hello World!" 的美好回忆。
- 感谢苏潼为本书设计了精美的封面和 LOGO在我的强迫症下多次耐心修改
- 感谢 @squidfunk 提供的写作排版建议,以及杰出的开源项目 [Material-for-MkDocs](https://github.com/squidfunk/mkdocs-material/tree/master) 。
本书鼓励“手脑并用”的学习方式,在这点上受到了《动手学深度学习》很大影响,也在此向各位同学强烈推荐这本著作,包括[中文版](https://github.com/d2l-ai/d2l-zh)、[英文版](https://github.com/d2l-ai/d2l-en)、[李沐老师 bilibili 主页](https://space.bilibili.com/1567748478)。
在写作过程中,我阅读了许多关于数据结构与算法的教材和文章。这些作品为本书提供了优秀的范本,确保了本书内容的准确性与品质。在此感谢所有老师和前辈们的杰出贡献!
在写作过程中,我阅读了许多数据结构与算法的教材与文章,这些著作为本书作出了很好的榜样,保证了本书内容的正确性与质量,感谢各位老师与前辈的精彩创作!
本书倡导“手脑并用”的学习方法,在此方面深受《动手学深度学习》的启发。在此向各位读者强烈推荐这本优秀著作,包括[中文版](https://github.com/d2l-ai/d2l-zh)、[英文版](https://github.com/d2l-ai/d2l-en)、[李沐老师 bilibili 主页](https://space.bilibili.com/1567748478)。
感谢父母,你们一的支持与鼓励给了我自由度来做这些有趣的事。
衷心感谢我的父母,正是你们一直以来的支持与鼓励,让我有机会做这些有趣的事。

View File

@@ -1,26 +1,28 @@
# 如何使用本书
建议通读本节内容,以获取最佳阅读体验。
!!! tip
为了获得最佳的阅读体验,建议您通读本节内容。
## 算法学习路线
总体上看,我认为可将学习数据结构与算法的过程分为三个阶段
总体上看,我们可以将学习数据结构与算法的过程分为三个阶段
1. **算法入门**。熟悉各种数据结构的特点用法,学习各种算法的原理、流程、用途效率等。
2. **刷算法题**可以先从热门题开刷,推荐[剑指 Offer](https://leetcode.cn/problem-list/xb9nqhhg/)[LeetCode Hot 100](https://leetcode.cn/problem-list/2cktkvj/),先积累至少 100 道题,熟悉大多数的算法问题。刚开始刷题时,“遗忘”是最大的困扰点,但这是很正常的,请不要担心。学习中有一种概念叫“周期性回顾”,同一道题隔段时间做一次,在重复 3 轮以上后,往往就能牢记于心了
3. **搭建知识体系**。在学习方面,可以阅读算法专栏文章、解题框架算法教材,不断丰富知识体系。在刷题方面,可以开始采用进阶刷题方案,例如按专题分类、一题多解、一解多题等,相关刷题心得可以在各个社区找到。
1. **算法入门**我们需要熟悉各种数据结构的特点用法,学习不同算法的原理、流程、用途效率等方面内容
2. **刷算法题**建议从热门题开刷,[剑指 Offer](https://leetcode.cn/problem-list/xb9nqhhg/)[LeetCode Hot 100](https://leetcode.cn/problem-list/2cktkvj/),先积累至少 100 道题,熟悉主流的算法问题。初次刷题时,“知识遗忘”可能是一个挑战,但请放心,这是很正常的。我们可以按照“艾宾浩斯遗忘曲线”来复习题目,通常在进行 3-5 轮的重复后,就能将其牢记在心
3. **搭建知识体系**。在学习方面,我们可以阅读算法专栏文章、解题框架算法教材,不断丰富知识体系。在刷题方面,可以尝试采用进阶刷题策略,如按专题分类、一题多解、一解多题等,相关刷题心得可以在各个社区找到。
作为一本入门教程,**本书内容主要对应“第一阶段”**,致力于帮助你更高效地开展第二、三阶段的学习。
作为一本入门教程,本书内容主要涵盖“第一阶段”,旨在帮助你更高效地展开第二和第三阶段的学习。
![算法学习路线](suggestions.assets/learning_route.png)
## 行文风格约定
标题后标注 `*` 的是选读章节,内容相对难。如果你的时间有限,建议可以先跳过。
标题后标注 `*` 的是选读章节,内容相对难。如果你的时间有限,建议可以先跳过。
文章中的重要名词会用 `「括号」` 标注,例如 `「数组 Array」`建议记住这些名词,包括英文翻译,以便后续阅读文献时使用。
文章中的重要名词会用 `「 」` 括号标注,例如 `「数组 Array」`请务必记住这些名词,包括英文翻译,以便后续阅读文献时使用。
重点内容、总起句、总结句会被 **加粗** ,此类文字值得特别关注。
**加粗的文字** 表示重点内容或总结性语句,这类文字值得特别关注。
专有名词和有特指含义的词句会使用 `“双引号”` 标注,以避免歧义。
@@ -156,41 +158,40 @@
## 在动画图解中高效学习
视频和图片相比于文字的信息密度和结构化程度更高,更容易理解。在本书中,**知识重难点会主要以动画图解形式呈现**,而文字的作用则是作为动画和图的解释与补充。
相较于文字,视频和图片具有更高的信息密度和结构化程度,因此更易于理解。在本书中,**重点和难点知识将主要通过动画图解形式展示**,而文字作为动画和图的解释与补充。
阅读本书时,发现某段内容提供了动画或图解,**建议以图为主线**文字内容(一般在图的上方)对齐到图中内容,综合来理解。
阅读本书时,如果发现某段内容提供了动画或图解,**建议以图为主线**文字(通常位于图像上方)为辅,综合两者来理解内容
![动画图解示例](suggestions.assets/animation.gif)
## 在代码实践中加深理解
本书的配套代码托管在[GitHub 仓库](https://github.com/krahets/hello-algo)**源代码包含详细注释,有测试样例,可直接运行**。
本书的配套代码托管在[GitHub 仓库](https://github.com/krahets/hello-algo)**源代码包含详细注释,并附有测试样例,可直接运行**。
- 若学习时间紧张,**建议至少将所有代码通读并运行一遍**
- 若时间允许,**强烈建议对照着代码自己敲一遍**。相比于读代码,写代码的过程往往能带来新的收获。
如果学习时间有限,建议至少通读并运行所有代码。如果时间充裕,**建议参照代码自行敲一遍**。与仅阅读代码相比,编写代码的过程往往能带来更多收获
![运行代码示例](suggestions.assets/running_code.gif)
**第一步:安装本地编程环境**。参照[附录教程](https://www.hello-algo.com/chapter_appendix/installation/),如果已有可直接跳过
**第一步:安装本地编程环境**。参照[附录教程](https://www.hello-algo.com/chapter_appendix/installation/)进行安装,如果已安装则可跳过此步骤
**第二步:下载代码仓**。如果已经安装 [Git](https://git-scm.com/downloads) ,可以通过命令行来克隆代码仓
**第二步:下载代码仓**。如果已经安装 [Git](https://git-scm.com/downloads) ,可以通过以下命令克隆本仓库
```shell
git clone https://github.com/krahets/hello-algo.git
```
当然你也可以点击“Download ZIP”直接下载代码压缩包本地解压即可。
当然你也可以点击“Download ZIP”直接下载代码压缩包然后在本地解压即可。
![克隆仓库与下载代码](suggestions.assets/download_code.png)
**第三步:运行源代码**。代码块顶部标有文件名称,则可在仓库 `codes` 文件夹中找到应的 **源代码文件**。源代码文件可以帮助你省不必要的调试时间,将精力集中在学习内容
**第三步:运行源代码**。如果代码块顶部标有文件名称,则可在仓库 `codes` 文件夹中找到应的源代码文件。源代码文件帮助你省不必要的调试时间,让你能够专注于学习内容。
![代码块与对应的源代码文件](suggestions.assets/code_md_to_repo.png)
## 在提问讨论中共同成长
阅读本书时,请不要“惯着”那些弄不明白的知识点。**欢迎在评论区留下你的问题**小伙伴们和我都会给予解答,一般 2 日内会得到回复。
阅读本书时,请不要“惯着”那些没学明白的知识点。**欢迎在评论区提出你的问题**我和其他小伙伴们将竭诚为你解答,一般情况下可在两天内得到回复。
同时,也希望你可以多花时间逛逛评论区。一方面,可以看看大家遇到了什么问题,反过来查漏补缺,这往往可以引起更加深度的思考。另一方面,希望你可以慷慨地解答小伙伴的问题、分享自己的见解,大家互相学习进步
同时,也希望您能在评论区多花时间。一方面,可以了解大家遇到的问题,从而查漏补缺,这将有助于激发更深入的思考。另一方面,希望您能慷慨地回答其他小伙伴的问题、分享的见解,大家共同学习进步
![评论区示例](suggestions.assets/comment.gif)

View File

@@ -1,8 +1,8 @@
# 小结
- 本书主要面向算法初学者。对于已经有一定积累的同学,本书可以帮助系统回顾算法知识,源代码可被当作“刷题工具库”使用。
- 书中内容主要分为复杂度分析、数据结构、算法三部分,盖了该领域的大部分主题。
- 对于算法小白,在初学阶段阅读一本入门书是非常有必要的,可以少走许多弯路。
- 书内的动画和图解往往介绍的是重点和难点知识,阅读时应该多加关注。
- 实践学习编程最佳方式,强烈推荐运行源代码,动手敲代码。
- 本书提供了讨论区,遇到疑惑可以随时提问
- 本书主要受众是算法初学者。对于已具备一定积累的同学,本书帮助系统回顾算法知识,同时源代码可作“刷题工具库”使用。
- 书中内容主要包括复杂度分析、数据结构、算法三部分,盖了该领域的大部分主题。
- 对于算法新手,在初学阶段阅读一本入门书籍至关重要,有助于避免走弯路。
- 书内的动画和图解通常用于介绍重点和难点知识,阅读时应给予更多关注。
- 实践学习编程最佳途径,强烈建议运行源代码并亲自敲打代码。
- 本书设有讨论区,欢迎随时分享你的疑惑