50+ 精选数据结构和算法面试问题 【译】

原文链接:https://hackernoon.com/50-data-structure-and-algorithms-interview-questions-for-programmers-b4b1ac61f5b0

译文原文:http://pengtuo.tech/algorithms/2018/10/02/data-structure-50/

本文的描述语言为 Java

image

有许多计算机科学专业毕业生或者程序猿会申请研发职位,在这个行业里有很多待遇比较好的大公司,例如国内的BAT,头条,美团等,国外也有亚马逊,谷歌以及 Facebook 等大型公司,但他们中的许多人都不知道当你在这些公司申请工作时会遇到什么样的编程面试问题

在本文中,我将与不同经验水平的程序猿分享一些常见的编程面试问题,涉及从刚从大学毕业的人到具有一到两年经验的程序员

研发面试主要由 数据结构和基于算法的问题 组成,也会有一些逻辑性的面试问题,例如 如何在不使用临时变量的情况下交换两个整数?

我认为将算法问题划分到不同的领域是非常有帮助的。我在面试中经常遇见的领域有数组、链表、字符串、二叉树,还有算法问题(例如字符串算法问题、排序算法问题,或者其他),并且这些都会在本文中提及。

我不能保证本文中的数据结构问题或者算法问题肯定会被问及,但是这些会让你充分了解实际面试中的遇到的各种问题以及解题思路。

一旦充分学习了这些问题,你应该有足够的信心参加任何电话面试或者线下面试。

顺便说一下,如果你没有认真学习过基本的数据结构和算法,或者你没有多年触及它们,那么还是建议你先去补充一下基础知识,再来研究本文的问题。

Top 50 算法和编程面试问题

话不多说,这里列出我在研发工作以及面试中一些最常见的算法面试问题列表:

1. 数组类面试问题

数组是最基本的数据结构,它将元素存储在连续的内存位置。这也是面试官很喜欢面试的方向,你会在任何算法面试中听到很多关于数组的问题,例如:反转数组,排序数组或搜索数组上的元素。

数组数据结构最大的优点是当知道索引时能够在 O(1) 的时间复杂度内搜索,但是向数组数据结构里添加和移除元素时会非常慢,因为数组一旦创建就不能更改其规格。当需要更改数组的大小时,则需要创建一个新的数组,然后从原先的数组中将元素拷贝到新的数组中。

解决基于数组类的算法问题的关键是要充分了解数组数据结构以及基本的编程技能,例如循环、递归等。

以下列出非常受欢迎的基于数组类的算法面试问题供你练习:

  1. 如何在一个给定的,范围是 1 到 100 的乱序整数数组中找到缺失的值?solution
  2. 如何在一个给定的整数数组中找到重复的数字?solution
  3. 如何在一个乱序的整数数组中找到最大值与最小值?solution
  4. 如何找到所有的整数对,其总和等于给定的数字?solution
  5. 如何在包含多个重复项的数组中找到重复的数字?solution
  6. 如何用 Java 语言在一个给定的数组中移除重复项?solution
  7. 请利用快速排序对一个数组进行原地排序。solution
  8. 如何用 Java 在原地反转一个数组?solution
  9. 请了解数组问题中的对撞指针和滑动窗口技巧

这些问题不仅能够帮助你提高解决问题的能力,还能更好的帮助你理解数组这个数据结构。如果你觉得这几道题不够联系,则可以查看 30 array question,也可以在 Leetcode或者Lintcode上的数组标签下找题目。

2. 链表类面试题

链表是另一种非常常见的数据结构。与数组结构类似,链表也是线性数据结构并且以线性的方式存储。

然而,和数组数据结构不同的是,在内存物理位置上数据元素并不是相邻的,相反,数据是分散存储在内存中,通过节点与其他数据相连。链表就是一系列的节点,其中每个节点存储着数据值和下一个节点的地址。

由于这种结构,在链表中添加和删除元素很容易,因为您只需要更改链接而不是创建数组,但搜索很困难,在单链表中通常需要花费 O(n) 时间来查找元素。

链表还有其他的变种,例如双向链表,允许在链表上两个方向(向前或向后)游走;还有循环链表,链表的首尾相连组合成一个圈。

为了解决基于链表的问题,需要对递归很了解,因为链表是递归数据结构。如果从链表中获取一个节点,则剩余的数据结构仍然是链表,因此,许多链表问题具有比迭代解决方案更简单的递归解决方案。

以下列出一些常见的受欢迎的链表的面试问题:

  1. 如何遍历一次就找到链表的中间节点?solution
  2. 如何判断一个链表是否有环?如何找到这个环的起始节点?solution
  3. 如何反转一个链表?solution
  4. 如何不使用递归的情况下反转链表?solution
  5. 如何从未排序的链表中移除重复节点?solution
  6. 请求出一个单链表的长度。solution
  7. 如何找出单链表的倒数第三个节点?solution
  8. 请对两个链表表示的整数求和,并返回链表。solution

这些问题将帮助您提高解决问题的能力,并提高您对链表数据结构的了解。如果对于以上这些问题感觉比较吃力,建议先补充链表的基础知识。你也可以联系30 linked list interview questions

3. 字符串类面试问题

与数组和链表数据结构同样,字符串类型是面试中的另一个热门话题。关于字符串问题的好消息是,如果你懂数组,你可以很容易地解决基于字符串的问题,因为字符串只是一个字符数组。

所以所有你的基于数组类问题的解题思路与技巧都可以用来解决字符串类型的问题。

以下是我列出的在工作面试中会被频繁问及的字符串类型问题:

  1. 如何将字符串中重复的字符打印出来?solution
  2. 如何判断两个乱序的字符串中的字母都相同?solution
  3. 请将字符串中第一个未重复的字符打印出来。solution
  4. 如何利用递归翻转一个字符串?solution
  5. 如何判断一个字符串中只包含数字字符?solution
  6. 请统计一个字符串中的元音和辅音的个数。solution
  7. 如何计算字符串中给定字符的出现次数?solution
  8. 请输出给定字符串的所有排列组合。solution
  9. 如何翻转给定句子中的单词?solution
  10. 如何判断两个字符串互为旋转?solution
  11. 如何判断一个字符是回文字符?solution

这些问题有助于提高您对字符串作为数据结构的了解。 如果你可以在没有任何帮助的情况下解决所有这些String问题,那么你很棒棒。

如果你需要更多的练习,可以看这里

4. 二叉树面试问题

到目前为止,我们只研究了线性数据结构,但现实世界中的所有信息都无法以线性方式表示,而这正是树数据结构所帮助的地方。

树数据结构是一种数据结构,允许以分层方式存储数据。 根据存储数据的方式,有不同类型的树,例如二叉树,其每个节点最多有两个子节点。以及其近亲,二叉搜索树,这个是最受欢迎的树形数据结构了。因此你会发现有很多的面试问题都是基于二叉树和二叉搜索树,例如 如何遍历,计算节点个数,找到树深度或者判断其是否为平衡树等。

解决二叉树问题的一个关键点是需要很扎实的理论基础,例如: 什么是二叉树的大小或深度,什么是叶子,什么是节点,以及对流行的遍历算法的理解,例如前中后序遍历。

以下是流行的基于二叉树的面试问题列表:

  1. 如何实现二叉搜索树?solution
  2. 请前序遍历一颗二叉树。solution
  3. 请不使用递归的情况下前序遍历一颗二叉树。solution
  4. 请中序遍历一颗二叉树。solution
  5. 请在不使用递归的情况下中序遍历一颗二叉树并输出。solution
  6. 如何实现后序遍历算法?solution
  7. 请在不使用递归的情况下后序遍历一颗二叉树。solution
  8. 如何输出一颗二叉搜索树的所有叶子结点?solution
  9. 如何统计一颗二叉树的所有叶子节点的个数。solution
  10. 如何在一个数组中执行二分搜索。solution

5. 各式面试问题

除了基于数据结构的问题之外,大多数面试中还会询问算法,设计,位操作和基于逻辑的一般问题,我将在本节中对其进行描述。

  1. 如何实现冒泡排序?solution
  2. 如何实现迭代快速排序算法?solution
  3. 如何实现插入排序算法?solution
  4. 如何实现归并排序算法?solution
  5. 如何实现桶排序算法?solution
  6. 如何实现计数排序算法?solution
  7. 如何实现基数排序算法?solution
  8. 如何在不使用第三个变量的情况下交换两个数字?solution
  9. 如何判断两个矩形是否互相重叠?solution
  10. 如何设计自动售货机?solution

顺便说一下,你在实践中解决的问题越多,你的准备就越好。 因此,如果您认为 50 还不够而且您需要更多,那么请查看这些额外的50个编程问题,以便进行更全面的准备。

现在,你应该准备好了

这些是数据结构和算法之外的一些最常见的问题,可以帮助您在面试中做得很好。这些常见的数据结构和算法问题是您在任何级别的技术面试都需要了解的问题。

如果您正在寻找开发工作,您可以使用此这些问题列表开始准备。此列表提供了准备的好主题,也有助于评估您的准备工作,以找出您的优势和劣势领域。熟悉数据结构和算法对于面试成功非常重要。

译者:欢迎大家访问我的个人博客与留言 http://pengtuo.tech

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容

  • 1.把二元查找树转变成排序的双向链表 题目: 输入一棵二元查找树,将该二元查找树转换成一个排序的双向链表。 要求不...
    曲终人散Li阅读 3,293评论 0 19
  • 音樂治疗临床技术 -SW中国音疗 1.五音应五脏疗疾与方法调理 音樂在我国已有8000年上下的可考历史证明,主要由...
    翟军伟音疗师阅读 767评论 0 1
  • 躺在床上又开始漫无目的的浮想联翩,将近一点了又要步入失眠的状态,可能是因为工作的缘故,每次都睡的比较晚,或许现在九...
    半岛玫瑰阅读 382评论 0 1
  • 第一天的“斗”作业用了将近三个小时,现在是23:03,我在完成了作业之后来进行另一项思想活动——日更,算上今天应该...
    布鲁斯J阅读 278评论 0 0
  • 最近比较烦比较烦比较烦,诸事不顺,甚至都要怀疑人生了,不得不承认我是个容易情绪容易悲观消极的人 突然接到好...
    A一路繁花相送阅读 348评论 1 1