首页 > 其他分享 >我如何回答编码面试问题的框架

我如何回答编码面试问题的框架

时间:2023-04-01 14:32:19浏览次数:81  
标签:编码 面试官 框架 fizzbuzz 代码 面试 result print fizz

image.png

我讨厌编码面试已经不是什么秘密了。

他们是一种糟糕的招聘方式并且容易出现误报(也就是不必要地拒绝优秀候选人)。对于大多数公司来说,提出白板式的问题并不符合他们的最大利益。

不幸的是,它们是行业标准。作为一名软件工程师,您必须在求职过程中回答白板上的问题。

所以,这是我如何擅长于它们的框架。

能力触发器

这个框架依赖于我在数十次面试过程中发现的一些能力触发器。我还看到这些技巧对我指导的工程师很有用。

我所说的“能力触发器”是指您可以展示的一种做法或可以说出的短语,可以清楚地表明您知道自己在说什么。向面试官发出信号的小而轻松的时刻:这个人明白了。

坐在桌子的两边,我知道最好的候选人在编码面试中会做一些关键的事情:

  • 提出好的问题来澄清需求
  • 编写测试并寻找边缘案例
  • 在陷入细节之前要全面思考

8步框架

这是我回答面试问题的过程。我在面试的任何时候都使用这个框架,每次几乎完全一样:

  1. 提出问题并重申预期目标——当面试官给你问题陈述时,问一些澄清问题并用你自己的话重申问题。即使您完全理解问题,也可以将此作为展示能力的一种方式。
  2. 搭建解决方案、伪代码——不要立即深入研究代码。相反,请使用注释/伪代码粗略地概述您的解决方案,以展示您的一般方法并让您从整体上考虑问题。
  3. 直截了当地说,“这看起来合理吗?我走在正确的轨道上吗?” — 在采访的早期阶段,征求反馈意见。让你的面试官有机会向你指出不同的方向。你会惊讶于面试官经常说:“听起来完全正确!” 或者,“有趣的是,你很接近,但你有没有考虑过……”Free 很早就暗示了解决方案!
  4. 编写一些实现,做简单的部分——不要太沉迷于困难的部分,而是用一些真实的代码替换你的伪代码,这样你就可以开始运行它了
  5. 编写快乐路径测试用例和测试运行器——这是一个巨大的能力触发器。预先编写一些简单的测试用例,为您的代码运行提供真实数据。目标应该是让您的代码尽快运行。
  6. 迭代代码,直到解决快乐路径测试用例——这是面试的实际工作。解决这个问题。但是请注意我们是如何只在第 6 步解决问题的。到目前为止,您已经为解决问题奠定了良好的基础。
  7. 寻求优化并直截了当地问,“这能更高效吗?” — 这是许多候选人错过的一步。与面试官一起寻找优化方法(如果有的话)。讨论运行时间和权衡。另一个重要的能力触发器是讨论权衡和替代实施的能力。
  8. 测试边角案例——当您的快乐路径测试案例正常运行时,不要就此止步。另一个重要的能力触发器是证明您了解如何查找边缘情况和处理错误。

Fizzbuzz 示例

假设您被问及经典的fizzbuzz 问题

  1. 从明确要求开始。我什么时候应该停止迭代?3 和 5 是否被硬编码为间隔,或者嘶嘶声和嗡嗡声除数是否可变?函数的返回值是多少?数字是字符串还是整数?
  2. 搭建解决方案——我需要一个空列表。有一个 for 循环来遍历整数。有一些逻辑可以决定将什么附加到每个整数的列表中。最后,我应该返回列表。我会直接问面试官,“这看起来合理吗?有什么我想念的吗?
  3. 编写一些解决方案——定义函数def fizzbuzz(stop: int)。初始化一个空列表result = []。开始一个循环for i in range(stop):。在循环中,我需要一些逻辑,但我们先不要深入。在循环中的某个时刻,我需要result.append(i). 然后,用 结束函数return result。这肯定还没有解决问题,但它给了我工作的结构。让我们运行它!
  4. 写一个测试用例——起初,我可能会做一些类似的事情print(fizzbuzz(3)),只是手动查看它是否打印出来[1, 2, 'fizz']。我可以python fizzbuzz.py从命令行运行它。但我们需要更全面的测试,所以我可能会创建一组test_cases并迭代它们以查看我的代码产生的结果。
  5. 迭代代码 — 现在,我实际上已经准备好搞乱 fizzbuzz 的逻辑了。我可以尝试我的代码并重新运行测试,直到我做对为止。
  6. 寻找优化——在这种情况下,可能没有太多优化。还是挺好看的。但这fizzbuzz是一个线性问题,因为您需要为每个整数打印一些东西。
  7. 测试极端情况——当你执行fizzbuzz(0)or时会发生什么fizzbuzz(-1)?我是否需要处理无效输入的情况,例如fizzbuzz('a')or fizzbuzz(None)

示例代码

昨晚我和一位教练客户一起完成了这个练习。这是我们在短短几分钟内使用该框架得出的结论:

def fizzbuzz(stop: int):
    """On multiples of 3, print 'fizz'
    On multiples of 5, print 'buzz'
    On multiples of both, print 'fizzbuzz'
    For all other numbers, print the number
    """
    result = []
    for x in range(1, stop+1):
        if x % 15 == 0:
            result.append('fizzbuzz')
        elif x % 3 == 0:
            result.append('fizz')
        elif x % 5 == 0:
            result.append('buzz')
        else:
            result.append(x)

    return result

test_cases = (
    (-1, []),
    (0, []),
    (1, [1]),
    (3, [1, 2, 'fizz']),
    (15, [1, 2, 'fizz', 4, 'buzz', 'fizz', 7, 8, 'fizz', 'buzz', 11, 'fizz', 13, 14, 'fizzbuzz']),
)

for stop, expected in test_cases:
    actual = fizzbuzz(stop)
    try:
        assert actual == expected
        print('PASS!')
    except:
        print(actual, expected)

框架的价值

在像面试这样压力很大的情况下,有一个可以依靠的框架是非常有价值的。当你觉得自己陷入困境时,只需按照步骤设置你需要的工具——脚手架、单元测试,以及你可以从面试官那里得到的任何提示。

希望这会有所帮助!关于面试还有​​其他问题或意见吗?给我回信。

每日清单

我每天早上都会为软件开发人员写一些新东西。

如果你喜欢我的文章,点赞,关注,转发!

标签:编码,面试官,框架,fizzbuzz,代码,面试,result,print,fizz
From: https://blog.51cto.com/u_12409319/6163559

相关文章

  • sublime编辑器中ANSI编码的汉字出现乱码
    问题:使用sublime打开一个ANSI编码的文件,出现乱码。解决方法:安装ConvertToUTF8插件打开sublime,按键Ctrl+Shift+p ,会出现如下图所示 然后,你输入installpackage点击InstallPackage,然后,你再输入ConvertToUTF8点击回车.这时,你可以在sublime的左下角看见提示,这说明正在安装C......
  • C语言逆向汇编——参数局部变量、函数堆栈、调用约定和内嵌汇编码
    第一节1.1C语言1、注意参数和局部变量在堆栈中的存储方式2、参数在调用函数前就已经存入堆栈,从[EBP+8]、[EBP+C]、……开始。3、局部变量是在调用函数后,存入缓冲区里,从[EBP-4]、[EBP-8]、……开始4、函数运算得到的结果,通常存在EAX里。        第一......
  • 测试面试题
    软件测试1、软件的定义?软件是一系列按特定顺序组织的计算机数据和指令的集合,包括与计算机系统操作有关的程序、规程、规则、文件、文档和数据。软件被划分为系统软件、应用软件和中间件。软件不仅包括电脑程序,还包括与这些程序相关的文档,可简单地理解为程序和文档的集合。2、......
  • 项目一众筹网07_01_SpringSecurity框架简介和用法、SpringSecurity负责的是 权限验证
    项目一众筹网07_01_SpringSecurity文章目录项目一众筹网07_01_SpringSecurity01简介SpringSecurity负责的是权限验证02-SpringSecurity简介03-Spring的注解模式maven引入Spring环境04-准备测试环境05-加入SpringSecurity环境06-实验1-放行首页和静态资源(下一篇)01简介现在主流的权......
  • 阶段小结:批量删除的时候使用 this.id的详解、jquery里面的$(this)和this的区别、面试
    this.id指的是当前对象的id比如我点击了button那么此button按钮的id就可以用this.id文章目录this.id指的是当前对象的id比如我点击了button那么此button按钮的id就可以用this.id我们先看项目里面方式1:利用样式,可以隐藏,但是不推荐方式二主角this.id方式:给点击删除的时候......
  • 渡一教育_每日一练:对象的加载、对象的创建相关知识面试题
    系列文章目录文章目录系列文章目录题目一:对象的加载、对象的创建相关知识面试题题目答案和解析题目一:对象的加载、对象的创建相关知识面试题题目答案和解析用内存图来做就很简单所以我们从上图可以看出,跟类加载机制有关系传参传参完毕之后,就开始执行那个方法了=最终的答案是D......
  • 项目一众筹网05_0项目阶段性总结,SSM框架_项目开发注意事项,,不要随意动框架预定好的结构
    系列文章目录文章目录系列文章目录一、框架搭建好之后,项目开发阶段,各就各位,尽量不要新建包名二、mybatis里面sql结束不要带分号三:实体的属性名最好跟数据库的字段保持一模一样,这样mybatis才不会因为大小写什么的而识别不了四:不是主键可以添加唯一约束吗五、idea里面的配置,需要注意......
  • 总结的面试题、数组下标为什么从0开始、数组名中存储的是什么、数组的元素如何存储
    系列文章目录文章目录系列文章目录第一题第二题第一题详细解答链接:https://mp.weixin.qq.com/s/N1Mj3DLbFkZeT5hVR05eNA第二题数组的存储:1、数组下标为什么从0开始?下标表示的是这个元素的位置距离首地址的偏移量2、数组名中存储的是什么数组名中存储的是数组在堆中一整块区域......
  • SpringMVC 框架的介绍
    Java早期的MVC模型主要使用Servlet组件。用户的请求首先到达Servlet,Servlet作为控制器接收请求,然后调度JavaBean读写数据库的数据,最后将结果放到jsp中展现给用户。但是,Servlet组件功能有限,而且与jsp的耦合度过高,使得基于Servlet组件的MVC架构开发很不方便......
  • Flask框架1
    今日内容概要flask和其他pythonweb框架介绍flask快速使用登陆显示用户信息小案例配置文件方式路由系统今日内容概要flask和其他pythonweb框架介绍pythonweb框架的本质都一样1.同步框架 django大而全内置的app多第三方app也多 flask小而精没有过多的内置组件......