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

适用于软件工程师编码面试的十大算法

时间:2020-07-21 13:31:42  来源:  作者:

您刚刚从大学获得计算机科学或软件工程学位,并且正在寻找职业。您还记得自己喜欢单身汉编写代码,并与好友一起做过一些很棒的项目,然后决定要成为一名开发人员。

您开始准备工作面试,却无法弄清楚记住哪些算法对于评分工作很重要。如果您处于这样的位置,并且足够快地进行面试,那么本文将帮助您记住求职面试可能需要的所有编码算法。

软件工程师的基本工作描述包括设计,增强和实施系统和应用程序。

为此,软件工程师无需记住许多复杂的算法。相反,要求他们使用工作库,框架和数据库的组合来创建满足其软件需求的工具。

根据软件工程领域的专家介绍,了解一些高级搜索算法在优化它们时会有所帮助,否则,您更有可能使用内置库。话虽如此,这里列出了一些重要的算法,在进行面试时您应该具有一些基本的知识。

适用于软件工程师编码面试的十大算法

 

动态编程

动态编程是通过消除对递归调用的需求来优化隐性函数的策略。每当我们看到一个递归函数,其中某个代码的某个部分被多次调用时,可以通过使用动态编程来大大改进。通过存储前一个子函数的结果,可以消除递归性,从而不必多次调用它们。这样可以将时间复杂度从指数时间降低到多项式时间。属于动态编程类别的算法示例如下:

二进制搜索

顾名思义,搜索算法用于从称为数据结构的给定集合中搜索元素。二进制搜索在提供排序后的元素数组和搜索键时有效。二进制搜索通过选择中间元素并将其与搜索关键字进行比较来实现,如果该关键字小于中间元素的左侧部分,则以相同的方式进行遍历。如果现在在右部分上搜索密钥。二进制搜索的时间复杂度为O(log n),其中n是数组中元素的数量。

排序算法

排序算法用于对数组进行排序,输入中包含需要排序的数据类型。数据集可以按升序或降序排序。以下是一些要记住的重要排序算法。

合并排序

合并排序基于分而治之算法的原理进行。它是指将问题分解为较小的部分,并一一解决并最终合并在一起的实践。合并排序将数组分为两半,并在两个半部分上调用sort函数,对这两个半部分进行排序,然后使用merge函数合并在一起。合并排序的时间复杂度为O(n log n)。

快速排序

像合并排序一样,快速排序也是基于分而治之的算法,它在排序功能方面与合并排序有所不同。Quicksort的工作原理是选择最后一个元素作为枢轴数字,并将其放在中间,左侧数字较小,而右侧数字较大。左侧和右侧再次使用sort函数进行调用,结果对整个数组进行了排序。快速排序的时间复杂度为O(n ^ 2)。

深度优先搜索

DFS是一种搜索算法,它从节点开始搜索过程,一直向下到最左边分支的最后一个叶子。在到达最左边的叶子之后,算法开始回溯并遍历树的右侧,依此类推。此DFS的问题在于,如果存在一个周期,则可以多次访问某个节点。DFS的时间复杂度为O(V + E),其中V和E分别表示图中的顶点和边数。

广度优先搜索

BFS是一种与DFS一样从根开始的搜索算法。但是,它没有遍历左侧的所有叶子,而是在同一级别上的节点附近搜索。遍历一个级别后,算法将前进到下一个级别,并继续遍历直到找到元素。BFS的时间复杂度与DFS相同,为O(V + E)。

自定义数据结构

有时,典型的预定义数据结构无法完成任务,您需要更好,更强大的功能。自定义数据结构可以是真实或抽象对象,具体取决于其数据成员的用途。数据成员可以视为属于指定对象的变量。

哈希表

哈希表是一种数据结构,用于存储,访问和修改时间为O(1)的数据。哈希数据结构使用哈希函数将给定值映射到特定键。然后,使用此密钥快速访问和检索这些值,哈希的执行效率取决于所使用的哈希函数的类型。

链表

通常,数组的组件或任何链接的数据结构存储在连续的内存位置中。这将占用空间,并且某些内存块不可访问(也就是说,如果内存不足)。为了克服这个问题,使用了链表数据结构,其中的数据不是连续存储的,而是列表中的每个项目都有一个指向下一个元素的存储位置的指针。第一个元素被称为头,最后一个元素被称为尾。

问问题

软件工程师应该知道的最重要的事情是询问客户。大多数客户无法理解他们的观点,如果开发人员不提出任何问题,则可能由于沟通不畅而引起问题。这样,您将能够理解他们正在努力实现的核心问题,而不仅仅是他们面临的困难。

结论

有了这些基本算法的知识,就可以轻松进行面试。请记住,软件工程师通常不依靠这些算法来完成工作。取而代之的是,它们被用来测试个人对他是否了解代码工作的理解。如此说来,祝您下次面试顺利。



Tags:算法   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
前言Kafka 中有很多延时操作,比如对于耗时的网络请求(比如 Produce 是等待 ISR 副本复制成功)会被封装成 DelayOperation 进行延迟处理操作,防止阻塞 Kafka请求处理线程。Kafka...【详细内容】
2021-12-27  Tags: 算法  点击:(1)  评论:(0)  加入收藏
分稀疏重建和稠密重建两类:稀疏重建:使用RGB相机SLAMOrb-slam,Orb-slam2,orb-slam3:工程地址在: http://webdiis.unizar.es/~raulmur/orbslam/ DSO(Direct Sparse Odometry)因为...【详细内容】
2021-12-23  Tags: 算法  点击:(7)  评论:(0)  加入收藏
一、什么是冒泡排序1.1、文字描述冒泡排序是一种简单的排序算法。它重复地走访要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地...【详细内容】
2021-12-15  Tags: 算法  点击:(16)  评论:(0)  加入收藏
前面文章在谈论分布式唯一ID生成的时候,有提到雪花算法,这一次,我们详细点讲解,只讲它。SnowFlake算法据国家大气研究中心的查尔斯·奈特称,一般的雪花大约由10^19个水分子...【详细内容】
2021-11-17  Tags: 算法  点击:(24)  评论:(0)  加入收藏
基于算法的业务或者说AI的应用在这几年发展得很快。但是,在实际应用的场景中,我们经常会遇到一些非常奇怪的偏差现象。例如,Facebook将黑人标记为灵长类动物、城市图像识别系统...【详细内容】
2021-11-08  Tags: 算法  点击:(32)  评论:(0)  加入收藏
随着注册制的加速推进,新股越来越多,截止到今天A股上市公司的总数高达4500余家,A股一直就是重融资,轻投资的市场,而上市公司发行可转债这种再融资的(圈钱方式)是最能让普通投资者接...【详细内容】
2021-11-05  Tags: 算法  点击:(98)  评论:(0)  加入收藏
导读:在大数据时代,对复杂数据结构中的各数据项进行有效的排序和查找的能力非常重要,因为很多现代算法都需要用到它。在为数据恰当选择排序和查找策略时,需要根据数据的规模和类型进行判断。尽管不同策略最终得到的结果完...【详细内容】
2021-11-04  Tags: 算法  点击:(40)  评论:(0)  加入收藏
这是我在网上找的资源的一个总结,会先给出一个我看了觉得还行的关于算法的讲解,再配上实现的代码: Original author: Bill_Hoo Original Address: http://blog.sina.com.cn/s/bl...【详细内容】
2021-11-04  Tags: 算法  点击:(36)  评论:(0)  加入收藏
每个人都有过这样的经历:打开手机准备回消息或打电话,一看到微信图标右上方的小红点,于是忍不住先打开微信;看完微信,不知不觉又被另一个App牵引,直到关闭手机屏幕才发现自己早已...【详细内容】
2021-11-03  Tags: 算法  点击:(30)  评论:(0)  加入收藏
文丨互联网怪盗团在互联网行业,尤其是在投资人心目中,往往存在一种“算法迷信”或曰“技术迷信”:某公司的广告变现做得好,一定是因为有算法;某公司的云计算业务开展的好,也是因为...【详细内容】
2021-11-03  Tags: 算法  点击:(25)  评论:(0)  加入收藏
▌简易百科推荐
前言Kafka 中有很多延时操作,比如对于耗时的网络请求(比如 Produce 是等待 ISR 副本复制成功)会被封装成 DelayOperation 进行延迟处理操作,防止阻塞 Kafka请求处理线程。Kafka...【详细内容】
2021-12-27  Java技术那些事    Tags:时间轮   点击:(1)  评论:(0)  加入收藏
博雯 发自 凹非寺量子位 报道 | 公众号 QbitAI在炼丹过程中,为了减少训练所需资源,MLer有时会将大型复杂的大模型“蒸馏”为较小的模型,同时还要保证与压缩前相当的结果。这就...【详细内容】
2021-12-24  量子位    Tags:蒸馏法   点击:(11)  评论:(0)  加入收藏
分稀疏重建和稠密重建两类:稀疏重建:使用RGB相机SLAMOrb-slam,Orb-slam2,orb-slam3:工程地址在: http://webdiis.unizar.es/~raulmur/orbslam/ DSO(Direct Sparse Odometry)因为...【详细内容】
2021-12-23  老师明明可以靠颜值    Tags:算法   点击:(7)  评论:(0)  加入收藏
1. 基本概念希尔排序又叫递减增量排序算法,它是在直接插入排序算法的基础上进行改进而来的,综合来说它的效率肯定是要高于直接插入排序算法的;希尔排序是一种不稳定的排序算法...【详细内容】
2021-12-22  青石野草    Tags:希尔排序   点击:(6)  评论:(0)  加入收藏
ROP是一种技巧,我们对execve函数进行拼凑来进行system /bin/sh。栈迁移的特征是溢出0x10个字符,在本次getshell中,还碰到了如何利用printf函数来进行canary的泄露。ROP+栈迁移...【详细内容】
2021-12-15  星云博创    Tags:栈迁移   点击:(22)  评论:(0)  加入收藏
一、什么是冒泡排序1.1、文字描述冒泡排序是一种简单的排序算法。它重复地走访要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地...【详细内容】
2021-12-15    晓掌柜丶韶华  Tags:排序算法   点击:(16)  评论:(0)  加入收藏
在了解golang的map之前,我们需要了解哈希这个概念。哈希表,又称散列表(Hash table),是根据键(key)而直接访问在内存储存位置的数据结构。也就是说,它通过计算出一个键值的函数,将...【详细内容】
2021-12-07  一棵梧桐木    Tags:哈希表   点击:(14)  评论:(0)  加入收藏
前面文章在谈论分布式唯一ID生成的时候,有提到雪花算法,这一次,我们详细点讲解,只讲它。SnowFlake算法据国家大气研究中心的查尔斯·奈特称,一般的雪花大约由10^19个水分子...【详细内容】
2021-11-17  小心程序猿QAQ    Tags:雪花算法   点击:(24)  评论:(0)  加入收藏
导读:在大数据时代,对复杂数据结构中的各数据项进行有效的排序和查找的能力非常重要,因为很多现代算法都需要用到它。在为数据恰当选择排序和查找策略时,需要根据数据的规模和类型进行判断。尽管不同策略最终得到的结果完...【详细内容】
2021-11-04  华章科技    Tags:排序算法   点击:(40)  评论:(0)  加入收藏
这是我在网上找的资源的一个总结,会先给出一个我看了觉得还行的关于算法的讲解,再配上实现的代码: Original author: Bill_Hoo Original Address: http://blog.sina.com.cn/s/bl...【详细内容】
2021-11-04  有AI野心的电工和码农    Tags: KMP算法   点击:(36)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条