您当前的位置:首页 > 电脑百科 > 程序开发 > 算法

程序员必须要掌握的算法?如何有效的学习算法?

时间:2023-10-29 14:21:59  来源:今日头条  作者:从程序员到架构师

最近看到网上有很多初学编程的小伙伴在问有哪些程序员必须要掌握算法,并且这些算法在面试的时候会被经常问到呢?如何能够系统性的学习算法?看着样子估计是要想往算法工程师方向努力了。那么下面我们就来带着这些问题来进行分享了。

比较重要的几个算法

深度优先搜索算法

深度优先搜索本质上其实是要从一个树状或者是网状的结构中去搜索到自己所需要的数据。深度优先的意思就是说按照一条线路一直往最深的地方查找,直到查找到最深处的时候发现没有继续往下的节点了,就回头,回到上一个岔路口,顺着新的岔路口继续往下按照同样的方式继续往最深处进行查找。

程序员必须要掌握的算法?如何有效的学习算法?

 

通过这种方式就可以将所有的最深节点的路径都走一遍,也就可以访问到整个树状结构或者是图状结构的所有节点。虽然算法是针对于树或者是图进行设计的,但是在实际问题中也有很多的体现。

这些实际的问题表面上与树或者是图没有太大的关系,但是依然采用的是深度优先搜索算法的思路。例如很多比较实际的数学问题,例如八皇后问题、数独等等。

那么我们如何将一个实际遇到的问题转化成深度优先搜索问题进行求解呢?

这就是在面试中问道算法有关问题的核心的考察内容,也是在学习一个算法的时候,需要去锻炼的点。很多的面试者都是对算法本身掌握的非常好了,但是一遇到面试官问道的实际问题,就不知道该如何应对了。

广度优先搜索

说完深度优先搜索就不得不说到与之对应的广度优先搜索了,与深度优先搜索一样,也是在树结构或者是图结构中进行应用,与深度优先不同的是,广度优先搜索在一开始进行遍历的时候,首先会将当前节点所连接的所有的节点都找到,然后在按照规则进行下一轮的查找。

程序员必须要掌握的算法?如何有效的学习算法?

 

也就是说广度优先搜索是一层一层的进行搜索,只有将当前节点所连接的最近的一层节点都走完了,才会继续去查找下一层的节点。然后持续迭代的走下去。

这有点像是剥开洋葱一样,你需要一层一层的剥开,要是想跳过一层的话就会导致洋葱损坏。

如果我们将深度优先和广度优先分别应用到查找迷宫的问题上,其区别也是非常明显的。深度优先,就是一直走,直到遇到墙的时候,回到岔路的位置继续进行查找。而广度优先则是首先在起点的时候就将所有的可能的路口都探寻一遍,然后找到最有可能有路口的路继续进行下一层次的探索。

这个时候就有人要问了,这两种算法到底哪种算法更好呢?只能说两种算法各有优缺点吧!广度优先最大的优点就是能够保证找到最短的路径,而深度优先不能。从迷宫问题就可以看出来,实际上在很多的著名的寻路算法中,很大一部分都是从广度优先搜索算法进行的扩展。例如著名的迪杰斯特拉算法、地图应用规划路径的算法等。

广度优先相比较于深度优先的缺点就是由于要存储上层节点信息,所以可能在就更容易占用内存

但是在一般的面试过程中遇到这种问题的时候,一般树或者图的深度都不是太大,所以一般就不考虑这问题。

二分查找算法

说完广度,接下要说的就是二分查找算法,这个算法适用在一个已经排好序的结构中例如在一个Storted Array 或者是在一个二叉查找树中。在搜索的过程中需要先取判断中间的节点是否是我们要找的数据,如果是的话那么正好找到,如果不是的话就需要判断该节点的数据与当前要查找的数据的大小,如果比该节点数据大那么从后半段进行查找,还是按照第一次查找的方式进行,如果比节点数据小那么就从前半段,按照第一次查找的方式进行查找。

程序员必须要掌握的算法?如何有效的学习算法?

 

通过这种递归的方式进行,就可以快速的找到需要的节点数据了。这个算法也是一种比较常用的算法,在JAVA中的TreeMap和TreeSet它们所用到的查找算法就是二分查找,又比如,在数据库中使用到的B+树索引,文件系统中的文件索引等等都用到了二分查找算法。

分治算法

这个算法与二分查找法的共同的特点就是将输入的内容分成两部分来分别进行处理,但是与二分查找法不同的是,分治算法会将分而治之的两部分按照同样的规则进行处理。也就是说两部分是都需要进行处理的,而二分法是指处理满足要求的一半。

程序员必须要掌握的算法?如何有效的学习算法?

 

分治算法的经典应用就是归并排序算法,理解非常简单,就是想要给一个大的数组进行排序的话,首先我们可以将其分成两个小的数组,然后分别对这两个小的数组进行排序,然后在对两个小数组按照规则进行最终的排序。

当然除了在排序算法中见到分治的身影,其实在分布式系统中,也会经常用到分治算法相关的思想。其中最著名的应用就是在MapReduce中的应用,通过对输入数据拆分成多个小份让这些小份被多个机器进行并行处理,然后将最终结果的合并,从而最终实现对大数据的处理。

如何学习算法?

以上,是在面试中经常会被问到的一些算法,其实,在实际开发过程中,我们可能遇到的数据结构的种类,或者是碰到的算法会更多,例如List、Queue、Stack、HashTable、Binary Tree、Graph、Heap,还有一些高级的数据机构Union Find、Trie等等。

我们在学习这些算法数据结构的时候,只从理论上出发的话是远远不够的,例如你知道二叉树的一些特征,一些实现原理、一些计算方式的时候,其实并不能代表你就会使用它。还是要从实际的编程语言中入手。

例如在Java中最为经典的也是在面试中会经常会被问到的HashMap的底层实现逻辑?在HashMap的底层采用了红黑树结构,如果只是将红黑树的理论知识背的滚瓜烂熟,在实际使用的时候不会用还是不会用。

所以我们要结合实际出发,通过实际的使用来提升自己对于数据结构的理解。

例如在很多的算法书籍中,提到的深度优先和广度优先用到的不是同一种数据结构。一个用到的是Stock、一个用到的是Queue。但是如果你对Java语言了解的话,在Java中是可以将一个Stock转换成一个Queue的,这个时候,你可能会对Stack和Queue两种数据结构有更加深刻的认识。什么意思呢?在理论上来讲,两种数据结构有着不同的定义,但是从代码实现的角度上,我们可以将一个Stock结构转换成一个Queue结构来使用。这就是理论与实践的差距。

总结

上面介绍了几种面试中常用的算法,以及如何能够有效的学习算法的方式。说白了,在学习算法的时候,一定要理论结合实践的方式来深入的理解算法。而不是生搬硬套的去背诵算法。一定要在理解的基础上然后去应用,而不是从书本上学来就直接进行套用,在这个多元化的氛围中,套用必然会被淘汰,只有不断的创新,灵活应用才是王道。



Tags:算法   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
诱导付费、自动扣费……微短剧被质疑借助算法精准“围猎”老年人
诱导付费、自动扣费、重复收费……聚焦身边的消费烦心事⑦丨一些微短剧被质疑借助算法精准“围猎”老年人中工网北京3月31日电(工人日报—中工网记者刘兵)...【详细内容】
2024-04-01  Search: 算法  点击:(5)  评论:(0)  加入收藏
分析网站SEO快速排名算法对网站具体的影响效果
亲爱的朋友们,今天我想和大家分享一个我们都关心的话题——网站SEO快速排名算法对网站我们身处一个信息爆炸的时代,如何在海量的信息中脱颖而出,成为了一个我们不得...【详细内容】
2024-03-28  Search: 算法  点击:(11)  评论:(0)  加入收藏
当prompt策略遇上分治算法,南加大、微软让大模型炼成「火眼金睛」
近年来,大语言模型(LLMs)由于其通用的问题处理能力而引起了大量的关注。现有研究表明,适当的提示设计(prompt enginerring),例如思维链(Chain-of-Thoughts),可以解锁 LLM 在不同领域的...【详细内容】
2024-03-12  Search: 算法  点击:(12)  评论:(0)  加入收藏
谷歌宣布更新搜索算法:打击AI生成内容,提高搜索结果质量
IT之家 3 月 6 日消息,谷歌于当地时间 5 日发文宣布,针对用户对搜索结果质量下降的反馈,将对算法进行调整,旨在打击 AI 生成的内容以及内容农场等垃圾信息,使用户能够看到更多“...【详细内容】
2024-03-06  Search: 算法  点击:(37)  评论:(0)  加入收藏
小红书、视频号、抖音流量算法解析,干货满满,值得一看!
咱们中国现在可不是一般的牛!网上的网友已经破了十个亿啦!到了这个互联网的新时代,谁有更多的人流量,谁就能赢得更多的掌声哦~抖音、小红书、、视频号,是很多品牌必争的流量洼地...【详细内容】
2024-02-23  Search: 算法  点击:(12)  评论:(0)  加入收藏
雪花算法详解与Java实现:分布式唯一ID生成原理
SnowFlake 算法,是 Twitter 开源的分布式 ID 生成算法。其核心思想就是:使用一个 64 bit 的 long 型的数字作为全局唯一 ID。在分布式系统中的应用十分广泛,且 ID 引入了时间戳...【详细内容】
2024-02-03  Search: 算法  点击:(50)  评论:(0)  加入收藏
简易百科之什么是搜索引擎的PageRank算法?
简易百科之什么是搜索引擎的PageRank算法?在互联网时代,搜索引擎是我们获取信息的重要工具。而PageRank算法则是搜索引擎的核心技术之一,它决定了网页在搜索结果中的排名。那么...【详细内容】
2024-01-24  Search: 算法  点击:(49)  评论:(0)  加入收藏
PageRank算法揭秘:搜索引擎背后的魔法师的工作原理
PageRank(PR)算法是由谷歌创始人之一的拉里·佩奇LarryPage命名的一种衡量网站页面重要性的方法。根据谷歌的说法,PageRank通过计算页面链接的数量和质量来粗略估计分...【详细内容】
2024-01-23  Search: 算法  点击:(44)  评论:(0)  加入收藏
程序开发中常用的十种算法,你用过几种?
当编写程序时,了解和使用不同的算法对解决问题至关重要。以下是C#中常用的10种算法,每个算法都伴随着示例代码和详细说明。1. 冒泡排序 (Bubble Sort):冒泡排序是一种简单的比...【详细内容】
2024-01-17  Search: 算法  点击:(44)  评论:(0)  加入收藏
百度最新的搜索引擎算法是什么样的?
百度搜索引擎算法是百度用来决定网页排名的算法。它是百度搜索技术的核心,也是百度作为全球最大的中文搜索引擎的基石。随着互联网的发展和用户需求的不断变化,百度搜索引擎算...【详细内容】
2024-01-10  Search: 算法  点击:(86)  评论:(0)  加入收藏
▌简易百科推荐
小红书、视频号、抖音流量算法解析,干货满满,值得一看!
咱们中国现在可不是一般的牛!网上的网友已经破了十个亿啦!到了这个互联网的新时代,谁有更多的人流量,谁就能赢得更多的掌声哦~抖音、小红书、、视频号,是很多品牌必争的流量洼地...【详细内容】
2024-02-23  二手车小胖说    Tags:流量算法   点击:(12)  评论:(0)  加入收藏
雪花算法详解与Java实现:分布式唯一ID生成原理
SnowFlake 算法,是 Twitter 开源的分布式 ID 生成算法。其核心思想就是:使用一个 64 bit 的 long 型的数字作为全局唯一 ID。在分布式系统中的应用十分广泛,且 ID 引入了时间戳...【详细内容】
2024-02-03   一安未来  微信公众号  Tags:雪花算法   点击:(50)  评论:(0)  加入收藏
程序开发中常用的十种算法,你用过几种?
当编写程序时,了解和使用不同的算法对解决问题至关重要。以下是C#中常用的10种算法,每个算法都伴随着示例代码和详细说明。1. 冒泡排序 (Bubble Sort):冒泡排序是一种简单的比...【详细内容】
2024-01-17  架构师老卢  今日头条  Tags:算法   点击:(44)  评论:(0)  加入收藏
百度推荐排序技术的思考与实践
本文将分享百度在推荐排序方面的思考与实践。在整个工业界的推广搜场景上,特征设计通常都是采用离散化的设计,需要保证两方面的效果,一方面是记忆,另一方面是泛化。特征都是通过...【详细内容】
2024-01-09  DataFunTalk  微信公众号  Tags:百度推荐   点击:(73)  评论:(0)  加入收藏
什么是布隆过滤器?如何实现布隆过滤器?
以下我们介绍了什么是布隆过滤器?它的使用场景和执行流程,以及在 Redis 中它的使用,那么问题来了,在日常开发中,也就是在 Java 开发中,我们又将如何操作布隆过滤器呢?布隆过滤器(Blo...【详细内容】
2024-01-05  Java中文社群  微信公众号  Tags:布隆过滤器   点击:(87)  评论:(0)  加入收藏
面向推荐系统的深度强化学习算法研究与应用
随着互联网的快速发展,推荐系统在各个领域中扮演着重要的角色。传统的推荐算法在面对大规模、复杂的数据时存在一定的局限性。为了解决这一问题,深度强化学习算法应运而生。本...【详细内容】
2024-01-04  数码小风向    Tags:算法   点击:(89)  评论:(0)  加入收藏
非负矩阵分解算法:从非负数据中提取主题、特征等信息
非负矩阵分解算法(Non-negativeMatrixFactorization,简称NMF)是一种常用的数据分析和特征提取方法,主要用于从非负数据中提取主题、特征等有意义的信息。本文将介绍非负矩阵分解...【详细内容】
2024-01-02  毛晓峰    Tags:算法   点击:(62)  评论:(0)  加入收藏
再谈前端算法,你这回明白了吗?
楔子 -- 青蛙跳台阶一只青蛙一次可以跳上一级台阶,也可以跳上二级台阶,求该青蛙跳上一个n级的台阶总共需要多少种跳法。分析: 当n=1的时候,①只需要跳一次即可;只有一种跳法,即f(...【详细内容】
2023-12-28  前端爱好者  微信公众号  Tags:前端算法   点击:(107)  评论:(0)  加入收藏
三分钟学习二分查找
二分查找是一种在有序数组中查找元素的算法,通过不断将搜索区域分成两半来实现。你可能在日常生活中已经不知不觉地使用了大脑里的二分查找。最常见的例子是在字典中查找一个...【详细内容】
2023-12-22  小技术君  微信公众号  Tags:二分查找   点击:(78)  评论:(0)  加入收藏
强化学习算法在资源调度与优化中的应用
随着云计算和大数据技术的快速发展,资源调度与优化成为了现代计算系统中的重要问题。传统的资源调度算法往往基于静态规则或启发式方法,无法适应动态变化的环境和复杂的任务需...【详细内容】
2023-12-14  职场小达人欢晓    Tags:算法   点击:(164)  评论:(0)  加入收藏
站内最新
站内热门
站内头条