0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

面试工程师还担心算法题不会?常见的都在这里

h1654155971.7688 2018-02-28 16:04 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群


算法是比较复杂又基础的学科,每个学编程的人都会学习大量的算法。而根据统计,以下这18个问题是面试中最容易遇到的,本文给出了一些基本答案,供算法方向工程师或对此感兴趣的程序员参考。

1)请简单解释算法是什么?

算法是一个定义良好的计算过程,它将一些值作为输入并产生相应的输出值。简单来说,它是将输入转换为输出的一系列计算步骤。

2)解释什么是快速排序算法?

快速排序算法能够快速排序列表或查询。它基于分割交换排序的原则,这种类型的算法占用空间较小,它将待排序列表分为三个主要部分:

小于Pivot的元素

枢轴元素Pivot(选定的比较值)

大于Pivot的元素

3)解释算法的时间复杂度?

算法的时间复杂度表示程序运行完成所需的总时间,它通常用大O表示法来表示。

4)请问用于时间复杂度的符号类型是什么?

用于时间复杂度的符号类型包括:

Big Oh:它表示小于或等于目标多项式

Big Omega:它表示大于或等于目标多项式

Big Theta:它表示与目标多项式相等

Little Oh:它表示小于目标多项式

Little Omega:它表示大于目标多项式

5)解释二分法检索如何工作?

在二分法检索中,我们先确定数组的中间位置,然后将要查找的值与数组中间位置的值进行比较,若小于数组中间值,则要查找的值应位于该中间值之前,依此类推,不断缩小查找范围,直至得到最终结果。

6)解释是否可以使用二分法检索链表?

由于随机访问在链表中是不可接受的,所以不可能到达O(1)时间的中间元素。因此,对于链表来说,二分法检索是不可以的(对顺序链表或排序后的链表是可以用的)。

7)解释什么是堆排序?

堆排序可以看成是选择排序的改进,它可以定义为基于比较的排序算法。它将其输入划分为未排序和排序的区域,通过不断消除最小元素并将其移动到排序区域来收缩未排序区域。

8)说明什么是Skip list?

Skip list数据结构化的方法,它允许算法在符号表或字典中搜索、删除和插入元素。在Skip list中,每个元素由一个节点表示。搜索函数返回与key相关的值的内容。插入操作将指定的键与新值相关联,删除操作可删除指定的键。

9)解释插入排序算法的空间复杂度是多少?

插入排序是一种就地排序算法,这意味着它不需要额外的或仅需要少量的存储空间。对于插入排序,它只需要将单个列表元素存储在初始数据的外侧,从而使空间复杂度为O(1)。

10)解释什么是“哈希算法”,它们用于什么?

“哈希算法”是一个哈希函数,它使用任意长度的字符串,并将其减少为唯一的固定长度字符串。它用于密码有效性、消息和数据完整性以及许多其他加密系统。

11)解释如何查找链表是否有循环?

要知道链表是否有循环,我们将采用两个指针的方法。如果保留两个指针,并且在处理两个节点之后增加一个指针,并且在处理每个节点之后,遇到指针指向同一个节点的情况,这只有在链表有循环时才会发生。

12)解释加密算法的工作原理?

加密是将明文转换为称为“密文”的密码格式的过程。要转换文本,算法使用一系列被称为“键”的位来进行计算。密钥越大,创建密文的潜在模式数越多。大多数加密算法使用长度约为64到128位的固定输入块,而有些则使用流方法。

13)列出一些常用的加密算法?

一些常用的加密算法是:

3-way

Blowfish

CAST

CMEA

GOST

DES 和Triple DES

IDEA

LOKI等等

14)解释一个算法的最佳情况和最坏情况之间有什么区别?

·最佳情况:算法的最佳情况解释为算法执行最佳的数据排列。例如,我们进行二分法检索,如果目标值位于正在搜索的数据中心,则这就是最佳情况,最佳情况时间复杂度为0。

·最差情况:给定算法的最差输入参考。例如快速排序,如果选择关键值的子列表的最大或最小元素,则会导致最差情况出现,这将导致时间复杂度快速退化到O(n2)。

15)解释什么是基数排序算法?

基数排序又称“桶子法”,是通过比较数字将其分配到不同的“桶里”来排序元素的。它是线性排序算法之一。

16)解释什么是递归算法?

递归算法是一个解决复杂问题的方法,将问题分解成较小的子问题,直到分解的足够小,可以轻松解决问题为止。通常,它涉及一个调用自身的函数。

17)提到递归算法的三个定律是什么?

所有递归算法必须遵循三个规律

递归算法必须有一个基点

递归算法必须有一个趋向基点的状态变化过程

递归算法必须自我调用

18)解释什么是冒泡排序算法?

冒泡排序算法也称为下沉排序。在这种类型的排序中,要排序的列表的相邻元素之间互相比较。如果它们按顺序排列错误,将交换值并以正确的顺序排列,直到最终结果“浮”出水面。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 工程师
    +关注

    关注

    59

    文章

    1603

    浏览量

    71215

原文标题:有备无患!面试中经常被问到的18个算法题

文章出处:【微信号:weixin21ic,微信公众号:21ic电子网】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    你知道电子工程师,到底分几种吗?

    第一种,硬件工程师:他们擅长画原理图、选元器件、调板子,是电路的专家、产品项目的“总导演”!第二种,软件工程师:脑子里全是代码,天天跟驱动、算法打交道,芯片怎么跑,他们说了算。第三种,固件工程
    的头像 发表于 04-20 08:52 61次阅读
    你知道电子<b class='flag-5'>工程师</b>,到底分几种吗?

    算力翻倍,工程师担心的不是芯片

    在华为中国合作伙伴大会2026上,这种变化被放大。昇腾950PR和Atlas 350的参数亮眼,但在工程侧,关注点已经发生变化:大家不再担心芯片能否跑满,而是如何确保复杂负载下,系统不会因为微小的时钟同步偏差而出现崩溃。
    的头像 发表于 03-23 17:06 377次阅读
    算力翻倍,<b class='flag-5'>工程师</b><b class='flag-5'>担心</b>的不是芯片

    什么是BSP工程师

    。嵌入式应用软件工程师主要是负责编写基于嵌入式系统的应用软件。类似于基于windows上的QQ, word。由于我本人是做BSP的,因此这里我们着重讨论BSP工程师。 三、BSP工程师
    发表于 01-13 06:54

    【限时折扣】RK3506到手仅需88元!原来资深工程师都在这里囤瑞芯微开发板

    在嵌入式技术快速迭代的今天,工程师们常常面临一个核心矛盾:如何在有限的预算内,选择既能满足当前项目需求,又能为未来技术升级预留空间的开发平台?尤其是在AIoT、边缘计算等场景对算力、接口、功耗提出
    的头像 发表于 11-18 08:06 597次阅读
    【限时折扣】RK3506到手仅需88元!原来资深<b class='flag-5'>工程师</b><b class='flag-5'>都在这里</b>囤瑞芯微开发板

    人工智能工程师高频面试题汇总:循环神经网络篇(题目+答案)

    后台私信雯雯老师,备注:循环神经网络,领取更多相关面试题随着人工智能技术的突飞猛进,AI工程师成为了众多求职者梦寐以求的职业。想要拿下这份工作,面试的时候得展示出你不仅技术过硬,还得能解决问题。所以
    的头像 发表于 10-17 16:36 849次阅读
    人工智能<b class='flag-5'>工程师</b>高频<b class='flag-5'>面试</b>题汇总:循环神经网络篇(题目+答案)

    小小UHF,大大乾坤|一个工程师眼里的连接器世界

    如果你想了解更多UHF连接器的真实细节,欢迎关注 德索连接器公众号。 在这里,有工厂的技术积累,也有我,一个工程师的碎碎念。
    的头像 发表于 10-15 18:02 2302次阅读
    小小UHF,大大乾坤|一个<b class='flag-5'>工程师</b>眼里的连接器世界

    硬件工程师面试必会:10个核心考点#硬件设计 #硬件工程师 #电路设计 #电路设计

    硬件工程师
    安泰小课堂
    发布于 :2025年09月23日 18:00:33

    电子发烧友工程师看!电子领域评职称,技术之路更扎实

    人才的重要标准。这类职称评审会看重实操能力(如嵌入式系统优化、代码效率提升案例)和技术认证(如 ARM 相关认证)。有位开发者提到,曾因缺少职称,在大厂面试中败给经验相当的对手;评上 “高级嵌入式工程师” 后
    发表于 08-20 13:53

    试工程师都在用的Linux命令清单(建议收藏)

    作为一名工程师,熟练掌握Linux命令是基本功中的基本功。无论是日常工作中的系统维护,还是面试时的技术考核,Linux命令都是绕不开的核心技能。本文将从实战角度出发,系统梳理工程师必须掌握
    的头像 发表于 08-08 10:06 830次阅读
    测<b class='flag-5'>试工程师</b><b class='flag-5'>都在</b>用的Linux命令清单(建议收藏)

    一个优秀的射频测试工程师需要具备哪些技能?

    一个优秀的射频测试工程师需要具备哪些技能?在无线技术高速发展的今天,射频(RF)测试工程师是确保通信设备性能与用户体验的关键角色。从复杂的调制方案到无处不在的干扰,从功耗优化到标准合规性,工程师需要
    的头像 发表于 05-16 10:08 2264次阅读
    一个优秀的射频测<b class='flag-5'>试工程师</b>需要具备哪些技能?

    硬件工程师面试/笔试经典 100

    分享一些常见的硬件工程师面试/笔试题。公众号后台回复关键字:100,可获取完整的PDF。--END--免责声明:本文转自网络,版权归原作者所有,如涉及作品版权问题,请及时与我们联系,
    的头像 发表于 04-30 19:34 1658次阅读
    硬件<b class='flag-5'>工程师</b><b class='flag-5'>面试</b>/笔试经典 100 <b class='flag-5'>题</b>