”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 我的 Amazon SDE 面试经历 – 5 月 4 日

我的 Amazon SDE 面试经历 – 5 月 4 日

发布于2024-11-08
浏览:773

我的 Amazon SDE 面试经历 – 2024 年 5 月

2024 年 5 月,我有机会面试亚马逊的软件开发工程师 (SDE) 职位。这一切都始于一位招聘人员通过 LinkedIn 联系我。我很惊喜,因为它总是令人兴奋。

一切是如何开始的

招聘人员专业且清晰,为我提供了有关流程和角色的所有必要细节。交换了几条消息后,我收到了第一轮面试的测试链接,这是一个编码评估。该评估在 HackerRank 上托管,包括两个编码问题。

第一轮 - 编码测试

问题很简单,但有点冗长。详细介绍如下:

1。第一个问题:条形码生成
任务是根据一些预定义的参数生成条形码。虽然这个问题本质上并不复杂,但需要注意细节以确保满足所有条件。我有条不紊地解决了这个问题,将其分解为更小的部分,并用 JavaScript 实现了一个解决方案。重点是效率和清晰度,确保生成的条形码符合预期的格式和约束。

2.第二个问题:具有部署状态的数组处理

这更多的是数据操作任务。输入由对象组成,每个对象都有一个部署 ID 和一个部署状态。我的目标是根据这些输入返回一个数组。虽然问题看起来很简单,但它也存在一些边缘情况。例如,有些物品缺少钥匙,乍一看并不明显。然而,在提交我的初始解决方案后,我意识到需要考虑这种边缘情况。我很快修改了代码来处理这些情况,确保丢失的键不会导致错误或不完整的结果。

My Amazon SDE Interview Experience – May 4
我使用 JavaScript 解决了这两个问题,并且确信我的解决方案通过了所有测试用例,包括隐藏的测试用例。

如果候选人解决​​了所有编码问题并通过了所有测试用例,亚马逊往往会推动候选人在这个过程中前进。

之后接到招聘人员的电话,说他正在推进面试流程,这将是现场面试。我有 5 天的时间来准备。

过去三年我一直在远程工作,从未去过办公室,所以我更害怕的是办公室而不是面试??

进一步的面试

我去了亚马逊办公室,那里已经没有几个候选人了。我们都去面试了。那天我进行了3轮技术面试。

1. 故障排除回合

第一轮是一次以故障排除为重点的面试。我一走进房间,就受到了一位非常支持我的面试官的欢迎。他在整个会议期间一直保持微笑,这有助于缓解我的紧张情绪。

他递给我一张纸,并提出了几个与系统故障、网络和网络层相关的问题。他使用的方法特别有趣。他让我首先考虑基本的解决方案——本质上是鼓励我从头开始解决问题。当我给出答案后,他稍微改变了场景,每一步都增加了更多的复杂性。

例如,在讨论网络故障后,他将对话转移到网络的更深层次,并问如果标准解决方案不起作用我会怎么做。这促使我创造性地思考并考虑系统中的各种故障点,从最常见到更复杂的问题。

面试让我在外面等,然后一位招聘人员来了,说我要去第二轮。

2. DSA 轮

下一轮是深入研究数据结构和算法(DSA)。这次,我的面试官是亚马逊的一位高级SDE。她递给我一张纸,并提出了一个相当大且复杂的问题。当我通读它时,我很快意识到主要目标是找到图中的最短路径。此类问题在面试中很常见,但当涉及边缘情况时可能会变得棘手,她肯定会包括在内。

我问了一些澄清问题,以充分理解问题及其各种场景。一旦我有了信心,我就开始研究解决方案——直接在纸上写伪代码。当我解释我的方法和逻辑时,她不断深入探究,询问我为什么做出某些决定以及我如何处理图表的不同部分。我向她介绍了我的思考过程,讨论了权衡和优化。幸运的是,我能够完整、正确地解答这道题。

一旦她对我的图形解决方案感到满意,她就问我有关时间和空间复杂度的问题,我向她分析并向她解释了这一点。很有成就感,觉得这一轮进展顺利。

然而,她很快转向另一个更具挑战性的问题——这次涉及动态规划(DP)。这个问题涉及到一个矩阵,其中不同的作物需要以遵循一定规则的方式种植。这是一个更复杂的问题,我花了一些时间来完全理解它。我问了几个问题,以确保涵盖所有限制和边缘情况。

我编写了一个伪代码解决方案,但它没有完全优化。她给了我一些测试用例,虽然我的代码在其中大约 80% 上运行成功,但仍有一些边缘用例失败了。我此时变得紧张,她注意到了这一点。幸运的是,她提供了有用的提示,我尝试进一步优化我的解决方案。尽管我尽了最大努力,但我无法完全解决这个问题,可能是因为我的神经占据了主导地位。

我又在外面等了,我对这一轮不是很高兴也没有信心,但是招聘人员又来了,说我的下一轮是系统设计。我好开心啊!

3. 系统设计回合

当天的最后一轮是系统设计面试,这是迄今为止最紧张、最疲惫的会议。面试官是亚马逊架构团队的一员,从一开始我就知道这一轮将具有挑战性。我们首先讨论了我的简历,重点讨论了我过去的项目以及我在之前工作中做出的设计决策。他问了几个关于我所开发的系统架构的问题,探讨了我的设计选择和我所做的权衡的细节。

经过初步讨论,他要求我为教育技术平台设计一个系统,特别关注视频流功能。目标是设计一个系统,教师可以在其中传输实时视频课程,学生可以在线参加这些课程。

我们从高层架构开始,讨论视频服务器、数据库和 API 等主要组件。我解释了我处理大量用户并确保流畅的视频流体验的方法。他不断询问可扩展性、可靠性和延迟问题,这对于实时视频平台至关重要。

当我们讨论完高层设计后,他将话题转向低层细节。这是讨论变得更加技术性的地方。我们探索了各种方法来优化系统、处理边缘情况,并确保即使在最坏的情况下也能为用户提供无缝体验。我必须迅速思考,为不同的问题提供解决方案和替代方案,包括处理用户流量峰值并确保最短的停机时间。

面试官不断地呈现不同的场景——如果视频服务器宕机了怎么办?您将如何处理网络拥塞?如何确保不同地理区域的学生的低延迟?每个场景都需要详细的答案,我发现自己完全沉浸在讨论可能性和设计模式中。

整个采访持续了大约1.5个小时,结束时我已经筋疲力尽了。这是一次精神上的疲惫,但也是我经历过的最有洞察力的采访之一。我们探索了各种架构挑战,感觉更像是一次协作解决问题的会议,而不是传统的采访。

所以我早上 9 点去了亚马逊办公室,晚上 5 点出来,我已经完成了所有轮次,招聘人员说他正在推进管理轮次, 尚未安排。

My Amazon SDE Interview Experience – May 4

无论如何忘了告诉你一件事,请在参加面试之前了解亚马逊的所有原则,他们每轮都会至少问2个问题。所以请也准备一下

版本声明 本文转载于:https://dev.to/naweli_verma/my-amazon-sde-interview-experience-may-2024-3nf6?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • HTML 格式标签
    HTML 格式标签
    HTML 格式化元素 **HTML Formatting is a process of formatting text for better look and feel. HTML provides us ability to format text without us...
    编程 发布于2024-12-23
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-12-23
  • 如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    在 PHP 中组合关联数组在 PHP 中,将两个关联数组组合成一个数组是一项常见任务。考虑以下请求:问题描述:提供的代码定义了两个关联数组,$array1 和 $array2。目标是创建一个新数组 $array3,它合并两个数组中的所有键值对。 此外,提供的数组具有唯一的 ID,而名称可能重合。要求...
    编程 发布于2024-12-23
  • 为什么我在 Laravel 中收到“Session store not set on request”错误?
    为什么我在 Laravel 中收到“Session store not set on request”错误?
    Laravel:解决“Session store not set on request”错误简介使用 Laravel 时,遇到“未根据请求设置会话存储”错误可能会令人沮丧。本文旨在提供对该问题的清晰解释和分步解决方案。错误是什么?“Session store not set on” request”...
    编程 发布于2024-12-23
  • 尽管代码有效,为什么 POST 请求无法捕获 PHP 中的输入?
    尽管代码有效,为什么 POST 请求无法捕获 PHP 中的输入?
    解决 PHP 中的 POST 请求故障在提供的代码片段中:action=''而不是:action="<?php echo $_SERVER['PHP_SELF'];?>";?>"检查 $_POST数组:表单提交后使用 var_dump 检查 $_POST 数...
    编程 发布于2024-12-23
  • 在 Go 中使用 WebSocket 进行实时通信
    在 Go 中使用 WebSocket 进行实时通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    编程 发布于2024-12-23
  • 如何在同一目录中组织一个库和 CLI 的 Go 项目?
    如何在同一目录中组织一个库和 CLI 的 Go 项目?
    在多包项目中组织代码在同时需要库和命令行界面 (CLI) 的 Go 项目中,经常会遇到以下问题在同一目录中有多个包。这样的项目结构:whatever.io/ myproject/ main.go myproject.go包 main 和 func main 对...
    编程 发布于2024-12-23
  • 如何在 Android 中选择后保持 ListView 项目突出显示?
    如何在 Android 中选择后保持 ListView 项目突出显示?
    如何在 Android 中选择后保持 ListView 项目突出显示在 Android 中,维护 ListView 项目的选定状态可以通过提供以下功能来增强用户体验:当前选择的清晰视觉指示器。然而,有时开发人员会遇到这样的问题:所选项目在某些事件(例如滚动或与 ListView 进一步交互)后失去突...
    编程 发布于2024-12-23
  • 如何使用自定义 CSS 在 Bootstrap 3 中创建全高列?
    如何使用自定义 CSS 在 Bootstrap 3 中创建全高列?
    Bootstrap 3 全高列:自定义 CSS 解决方案简介:创建Twitter Bootstrap 3 的全高布局可能具有挑战性。虽然Bootstrap的原生类不支持此功能,但可以使用自定义CSS来实现此效果。自定义CSS方法:设置100% 高度:将 body、container 和 row 元素...
    编程 发布于2024-12-23
  • 除了“if”语句之外:还有什么地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    除了“if”语句之外:还有什么地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    无需强制转换即可上下文转换为 bool您的类定义了对 bool 的显式转换,使您能够在条件语句中直接使用其实例“t”。然而,这种显式转换提出了一个问题:“t”在哪里可以在不进行强制转换的情况下用作 bool?上下文转换场景C 标准指定了四种值可以根据上下文转换为的主要场景bool:语句:if、whi...
    编程 发布于2024-12-23
  • 如何在不使用链接的情况下向 Span 元素添加工具提示?
    如何在不使用链接的情况下向 Span 元素添加工具提示?
    向不带链接的 Span 元素添加工具提示将鼠标悬停在 span 元素上时,通常需要向用户提供附加信息。这可以使用工具提示来实现,而不依赖于链接。解决方案:要使用内置 HTML 属性将工具提示添加到 span 元素,只需按如下方式使用 title 属性:<span title="My ...
    编程 发布于2024-12-23
  • 为什么我的 WebSocket 服务器在 Docker 化后无法连接?
    为什么我的 WebSocket 服务器在 Docker 化后无法连接?
    Docker化 WebSocket 服务器问题开发人员在尝试使用 Docker 容器化 WebSocket 服务器时遇到问题。服务器代码使用“connected”写入新连接,并且在容器外运行良好,但当放置在 Docker 容器内时,客户端会由于“连接重置”错误而出现恐慌,并显示错误消息“read t...
    编程 发布于2024-12-23
  • 如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    MySQL配置不正确:相对路径的问题在Django中运行python manage.py runserver时,可能会遇到以下错误:ImproperlyConfigured: Error loading MySQLdb module: dlopen(/Library/Python/2.7/site-...
    编程 发布于2024-12-23
  • Python中如何导入同目录或子目录中的类?
    Python中如何导入同目录或子目录中的类?
    在Python中从同一目录或子目录导入类在Python中,您可以通过以下方式从同一目录或子目录中的文件导入类利用 __init__.py 文件。该文件是一个空占位符,指示该目录包含模块和包。从同一目录导入从与 main 相同的目录中的文件导入类.py,在该目录中创建一个 __init__.py 文件...
    编程 发布于2024-12-23
  • 为什么C90中函数名可以用作函数指针?
    为什么C90中函数名可以用作函数指针?
    使用函数名称作为函数指针C90 的基本原理文档深入了解了将函数名称与函数指针等同的设计选择。这种便利简化了在特定上下文中使用函数指针的过程。函数声明考虑声明:int f(); int (*pf)();函数调用以下所有表示有效的函数调用:(&f)(); f(); (*f)(); (**f)()...
    编程 发布于2024-12-23

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3