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

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

相关文章

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

康拓展开(hash算法中会用到)

康拓展开是一个全排列到一个自然数的双射(也就是某个全排列与某个自然数一一对应) 公式: X=a[n]*(n-1)!+a[n-1]*(n-2)!+...+a[i]*(i-1)!+...+a[1]*0! 其中,a[i]为整数,并且0<=a[i]<i,1<=i<=n。(a[i]在不同应用中的含义不同); 典型应用: 计算当前排列在所有由小到大全排列中的顺序,也就是说求当前排列是第

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

poj 3974 and hdu 3068 最长回文串的O(n)解法(Manacher算法)

求一段字符串中的最长回文串。 因为数据量比较大,用原来的O(n^2)会爆。 小白上的O(n^2)解法代码:TLE啦~ #include<stdio.h>#include<string.h>const int Maxn = 1000000;char s[Maxn];int main(){char e[] = {"END"};while(scanf("%s", s) != EO

秋招最新大模型算法面试,熬夜都要肝完它

💥大家在面试大模型LLM这个板块的时候,不知道面试完会不会复盘、总结,做笔记的习惯,这份大模型算法岗面试八股笔记也帮助不少人拿到过offer ✨对于面试大模型算法工程师会有一定的帮助,都附有完整答案,熬夜也要看完,祝大家一臂之力 这份《大模型算法工程师面试题》已经上传CSDN,还有完整版的大模型 AI 学习资料,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费

防近视护眼台灯什么牌子好?五款防近视效果好的护眼台灯推荐

在家里,灯具是属于离不开的家具,每个大大小小的地方都需要的照亮,所以一盏好灯是必不可少的,每个发挥着作用。而护眼台灯就起了一个保护眼睛,预防近视的作用。可以保护我们在学习,阅读的时候提供一个合适的光线环境,保护我们的眼睛。防近视护眼台灯什么牌子好?那我们怎么选择一个优秀的护眼台灯也是很重要,才能起到最大的护眼效果。下面五款防近视效果好的护眼台灯推荐: 一:六个推荐防近视效果好的护眼台灯的

dp算法练习题【8】

不同二叉搜索树 96. 不同的二叉搜索树 给你一个整数 n ,求恰由 n 个节点组成且节点值从 1 到 n 互不相同的 二叉搜索树 有多少种?返回满足题意的二叉搜索树的种数。 示例 1: 输入:n = 3输出:5 示例 2: 输入:n = 1输出:1 class Solution {public int numTrees(int n) {int[] dp = new int