畅销书《算法图解》推荐!文末留言赠书!

2023-10-12 06:30

本文主要是介绍畅销书《算法图解》推荐!文末留言赠书!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

大家知道“猜数字”这个游戏吗?顾名思义就是一个人想一个数字,另一个人猜。这个游戏简单又有趣,小编小时候很喜欢玩。

游戏开始了!小伙伴从 1~100 中任选一个数字记在心里让我猜,我每猜一个数字,他只能说小了、大了或对了。直到我猜到数字,游戏结束。

04853d091b3f6db7d3adfb166c917fd0.png

那时的我比较笨,总是从 1 开始依次往上猜……

df5c1e155eced757b77f374342b72218.png

1,小了。那就是 2,2 也小。那就是 3……就这样一个一个猜测数字花费了很长时间。如果他定的数字是 99,那我要猜 99 次才能猜到!小伙伴表示很无奈,后来也不想再和我玩了。

长大之后的一次偶然的机会,我看到了一本书叫《算法图解》。这本书上竟然提到了小时候我玩的“猜数字”游戏,我才了解到,这个游戏不是最终猜到这个数字就算赢,而是又快又准确地猜到数字,那才是高手!那如何快速准确地猜到数字呢?书中告诉了我们“猜数字”游戏快速胜出的小窍门,让我大呼神奇,茅塞顿开。

首先从 50 开始猜。

60ebe2bb8ee448259b83a7838a96c5f2.png

小了,但我们可以排除一半的数字!1~50 都小了。接下来,猜 75。

6f03facecaa838151d61eda7fadb3103.png

大了,那余下的数字又排除了一半!75~100 都可以排除。接下来,猜 63(50 和 75 中间的数字)。

30b5adf595defa29384acbc3b767a34c.png

大了,但又可以排除一半数字!可以从 51~62 中选了!

接下来,猜 57(50 和 63 中间的数字)。对了!

书中说到,这种猜测方式其实就是算法的二分查找。没想到小小的游戏也用到了算法。使用这种方法每次都能排除一半的数字。不管定数字的人心里想的是哪个数字,在 7 次之内都能猜到。

4ad232616f7234e2ba7b3bc925277833.png

而我小时候一个一个数字排除的那种方法其实也是一种方法,叫简单查找,只不过这种方法比较笨。相比于简单查找,二分查找大大节省了时间提高了效率。那么使用二分查找可节省多少时间呢?

简单查找逐个地猜测数字,上面 100 个数字,最多需要猜 100 次。如果从 40 亿个数字中猜呢?最多需要猜 40 亿次。最多需要猜测的次数与列表长度相同,这被称为线性时间(linear time)。

如果用二分查找的方式,二分查找的运行时间为对数时间(或 log 时间)。100 个数字,最多要猜 7 次;40 亿个数字,最多只需猜 32 次。厉害吧?看看是不是节省了很多时间呢?

d956a985701d9743953da913334e1c35.png

后来我再玩这个游戏,使用了二分查找方法,总是能很快的猜对,所向披靡,屡战屡胜。其实不光是在这个游戏中二分查找起到很大的作用,在日常的工作生活中,使用二分查找也同样可以大大提高效率,节约时间,帮助我们解决问题。

比如,一个工人要维修一条 10km 长的电话线,想迅速查出故障所在。如果沿着线路一小段一小段查找,就很困难要花费很长时间(简单查找)。如果使用二分查找,把电线两端设为 A、B,中点为 C,发现 BC 段有故障,再找到 BC 中点 D,发现 CD 段有故障,再找到 CD 中点 E……这样每查一次,待查线路长度就缩减了一半,经过 7 次查找,就可以找到故障发生的范围了。

二分查找这么厉害,那下面我们再来看看如何编写执行二分查找的 Python 代码吧!这里的代码示例使用了数组。可将一系列元素存储在一系列相邻的桶(bucket),即数组中。这些桶从 0 开始编号:第一个桶的位置为 #0,第二个桶为 #1,第三个桶为 #2,以此类推。

函数 binary_search 接受一个有序数组和一个元素。如果指定的元素包含在数组中,这个函数将返回其位置。我们将跟踪要在其中查找的数组部分——开始时为整个数组。

36993c2afef8294eb8498bec0f57beba.png

我们每次都检查中间的元素。

99b168ee301d777a5121a93728792552.png

如果猜的数字小了,就相应地修改 low。

33bd0c7fae7475bcf0993579eee0358d.png

如果猜的数字大了,就修改 high。完整的代码如下。

2c63eddfbd9ec1accc9c5ab08cb90d04.png

你学会二分查找了吗?那让我们做一个小练习吧。假设有一个包含 128 个名字的有序列表,我们要使用二分查找在其中查找一个名字,请问最多需要几步才能找到?(PS:评论区留言,第一个猜对的小伙伴,我们将有礼品相送~)

——以上内容截选自《算法图解》

69c6ac5d28f26d7d08d6397eef56e876.gif

有些算法学习者可能有过这样的经历,学习算法初期看了几本大块头的经典算法巨著,但是看过就忘,对二分查找、大 O 表示法、递归、K 最近邻算法等算法还是迷迷糊糊,不知所云。慢慢地就对算法失去了兴趣,最终放弃。

算法巨著固然很好,但难度太大不适合刚入门的小白,初期学习算法,还是培养兴趣最为重要。如果算法书能像小说一样有趣的话,相信很多人不会放弃算法了。

上面提到的《算法图解》这本书就像小说一样有趣。比如“猜数字”游戏,通过这个例子,大家可以轻松掌握理解二分查找的概念,算法也不再枯燥乏味难懂了。

书中一步步用图的方式把算法解析出来,算法举例简单易懂,图文并茂,公式极少。通过这本书算法初学者可以轻松理清算法基础概念,潜移默化地培养算法思维,提升兴趣,帮助大家步入算法殿堂。

ff3cdf26d868d9cacc0213a6d6c6f569.png

下面是读者朋友在豆瓣的真实评价:

3b7aa30866c36a364585cd0d4c3c655e.png

5dcc932101f8d9d1b94f485caa8ae373.png

作者:【美】巴尔加瓦(Aditya Bhargava)

译者:袁国忠

本书特色

  • 你一定能看懂的算法基础书

  • 代码示例基于 Python

  • 400 多个示意图,生动介绍算法执行过程

  • 展示不同算法在性能方面的优缺点

  • 教会你用常见算法解决每天面临的实际编程问题

8084514a52e344eddc3f7b0bdd1ad6ed.png

你问我答

b4ee1259a0f1a2bb89e8233a95266b31.png

目录

a70672f7c2a41b1e232939213e545b46.png

d93a29f155b114800b6eefb7505026c4.png

大佬推荐

本书完成了一项不可能完成的任务:让数学变得有趣而易懂! 

——Sander Rossel,COAS Software Systems

你渴望像看喜欢的小说一样学习算法吗?如果是,本书正是你梦寐以求的!

——Sankar Ramanathan,IBM Analytics

当今世界,使用算法进行优化已渗透到了生活的方方面面。如果你正寻找优秀的算法入门书,本书就是你的首选。   

——Amit Lamba,Tech Overture

算法学习起来一点都不乏味!在我和学生们看来,本书既活泼有趣又富有洞见。

——Christopher Haupt,Mobirobo

87103db40b4aec0c015dd46d307b1d41.png

作译者介绍

作者

Aditya Bhargava

软件工程师,兼具计算机科学和美术方面的教育背景,在 adit.io 撰写编程方面的博客。

译者

袁国忠

自由译者;2000 年起专事翻译,主译图书,偶译新闻稿、软文;出版译著 40 余部,其中包括《Python编程:从入门到实践》《C++ Prime Plus中文版》《CCNA学习指南》《CCNP ROUTE学习指南》《面向模式的软件架构:模式系统》《风投的选择:谁是下一个十亿美元级公司》等,总计 700 余万字;专事翻译前,从事过三年化工产品分析和开发,做过两年杂志和图书编辑。

95e27026b4e232ef7fdb152d04b6c095.png

在文章底部留言,即可参加活动,留言获赞最高前五名粉丝将赠一本!包邮到家!

截止时间:2月21日   20:00整

没有抽中的粉丝不要气馁,打开下面链接,快快来抢购吧~

活动结束后,请读者直接加我的微信领取奖品!

a228d0104c066d32c5739500e6ed09e1.png

bf27e6342f1b72aa2814340fcada5cc7.png

详情点击“阅读原文”☟

这篇关于畅销书《算法图解》推荐!文末留言赠书!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/193938

相关文章

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

Knife4j+Axios+Redis前后端分离架构下的 API 管理与会话方案(最新推荐)

《Knife4j+Axios+Redis前后端分离架构下的API管理与会话方案(最新推荐)》本文主要介绍了Swagger与Knife4j的配置要点、前后端对接方法以及分布式Session实现原理,... 目录一、Swagger 与 Knife4j 的深度理解及配置要点Knife4j 配置关键要点1.Spri

Qt QCustomPlot库简介(最新推荐)

《QtQCustomPlot库简介(最新推荐)》QCustomPlot是一款基于Qt的高性能C++绘图库,专为二维数据可视化设计,它具有轻量级、实时处理百万级数据和多图层支持等特点,适用于科学计算、... 目录核心特性概览核心组件解析1.绘图核心 (QCustomPlot类)2.数据容器 (QCPDataC

Java内存分配与JVM参数详解(推荐)

《Java内存分配与JVM参数详解(推荐)》本文详解JVM内存结构与参数调整,涵盖堆分代、元空间、GC选择及优化策略,帮助开发者提升性能、避免内存泄漏,本文给大家介绍Java内存分配与JVM参数详解,... 目录引言JVM内存结构JVM参数概述堆内存分配年轻代与老年代调整堆内存大小调整年轻代与老年代比例元空

深度解析Java DTO(最新推荐)

《深度解析JavaDTO(最新推荐)》DTO(DataTransferObject)是一种用于在不同层(如Controller层、Service层)之间传输数据的对象设计模式,其核心目的是封装数据,... 目录一、什么是DTO?DTO的核心特点:二、为什么需要DTO?(对比Entity)三、实际应用场景解析

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

Go语言中nil判断的注意事项(最新推荐)

《Go语言中nil判断的注意事项(最新推荐)》本文给大家介绍Go语言中nil判断的注意事项,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.接口变量的特殊行为2.nil的合法类型3.nil值的实用行为4.自定义类型与nil5.反射判断nil6.函数返回的

python 常见数学公式函数使用详解(最新推荐)

《python常见数学公式函数使用详解(最新推荐)》文章介绍了Python的数学计算工具,涵盖内置函数、math/cmath标准库及numpy/scipy/sympy第三方库,支持从基础算术到复杂数... 目录python 数学公式与函数大全1. 基本数学运算1.1 算术运算1.2 分数与小数2. 数学函数

Python Pillow 库详解文档(最新推荐)

《PythonPillow库详解文档(最新推荐)》Pillow是Python中最流行的图像处理库,它是PythonImagingLibrary(PIL)的现代分支和继承者,本文给大家介绍Pytho... 目录python Pillow 库详解文档简介安装核心模块架构Image 模块 - 核心图像处理基本导入

CSS Anchor Positioning重新定义锚点定位的时代来临(最新推荐)

《CSSAnchorPositioning重新定义锚点定位的时代来临(最新推荐)》CSSAnchorPositioning是一项仍在草案中的新特性,由Chrome125开始提供原生支持需... 目录 css Anchor Positioning:重新定义「锚定定位」的时代来了! 什么是 Anchor Pos