拉勾网ThoughtWorks面试题代码实现
今天看到一个很有意思的面试活动(活动链接),不需要简历,只有一道编程题目,在线提交你的代码即可。
本菜鸟对面试不感兴趣,但题目让我很兴奋,特来挑战一下~
或许当你看到这篇博文的时候活动已经失效了,所以小菜就把题目记下来:
大道至简,知易行难!
我们的题目简约而不简单,千万不要轻敌,即使简单的代码,做到尽善尽美一样难能可贵,所以,提交之前,请想一想,它是不是可以更卓越,有人可以10行搞定,亲,你呢 :)
代码要求:
1,语言不限,Java, C#, Ruby, C++, Js, Python, Scala, objective-C统统可以,小语种也没问题,只要你擅长;
2,强烈建议写单元测试;
3,请展示出你超赞的面向对象/函数式编程功底;
4,建议尽量减少圈复杂度;
5,请提交可运行的代码,及相关构建脚本/说明文档(代码运行平台和环境);
FizzBuzzWhizz
你是一名体育老师,在某次课距离下课还有五分钟时,你决定搞一个游戏。此时有100名学生在上课。游戏的规则是:
1. 你首先说出三个不同的特殊数,要求必须是个位数,比如3、5、7。
2. 让所有学生拍成一队,然后按顺序报数。
3. 学生报数时,如果所报数字是第一个特殊数(3)的倍数,那么不能说该数字,而要说Fizz;如果所报数字是第二个特殊数(5)的倍数,那么要说Buzz;如果所报数字是第三个特殊数(7)的倍数,那么要说Whizz。
4. 学生报数时,如果所报数字同时是两个特殊数的倍数情况下,也要特殊处理,比如第一个特殊数和第二个特殊数的倍数,那么不能说该数字,而是要说FizzBuzz, 以此类推。如果同时是三个特殊数的倍数,那么要说FizzBuzzWhizz。
5. 学生报数时,如果所报数字包含了第一个特殊数,那么也不能说该数字,而是要说相应的单词,比如本例中第一个特殊数是3,那么要报13的同学应该说Fizz。如果数字中包含了第一个特殊数,那么忽略规则3和规则4,比如要报35的同学只报Fizz,不报BuzzWhizz。
现在,我们需要你完成一个程序来模拟这个游戏,它首先接受3个特殊数,然后输出100名学生应该报数的数或单词。比如,
输入
3,5,7
输出(片段)
1
2
Fizz
4
Buzz
Fizz
Whizz
8
Fizz
Buzz
11
Fizz
Fizz
Whizz
FizzBuzz
16
17
Fizz
19
Buzz
…
一直到100
题目本身并不难,但考察了很多细节。
比如,"建议写单元测试"、"面向对象/函数式编程功底",应该是考察的重点;"有人可以10行搞定",这纯属骗人,不是说不可以用10行代码搞定,靠一些非常规技巧,是可以实现,但这显然不是可维护的代码,也展现不出你的功力,当真你就上当了。
小菜选用的语言是JavaScript,因为她比较简单,也不需要什么环境,浏览器就可以了~
小菜写的仅仅是一个简单实现,给大家分享思路,不足之处多多包涵。
fbw.js
//定义游戏封装"类"
//max 整数上限,params 规定的数据结构
var fbw = function(max,params){
this.params = params;
//逻辑集合(以下划线开头的变量表示私有,外部不应调用)
this._logics = [];
//定义核心执行接口
this._exec = function(){
var list = [];
//遍历整数
for(var i=1;i<=max;i++){
var buffer = "";
//遍历特殊数
for(var j=0;j<params.length;j++){
var _j = params[j];
//遍历规则
for(var k=0;k<_j.rules.length;k++){
var _k = _j.rules[k];
var result = this._logics[_k](i,_j);
if(result != null){
buffer += result;
break;
}
}
}
//填入列表
if(buffer){
list.push(buffer);
}else{
list.push(i);
}
} return list;
};
} //定义输出接口
fbw.prototype.getFBW = function(){
//1.重新组织逻辑集合
this._logics = [];
//规则中参数统一:n目标数,o特殊数对象
//规则4(实际上第三条和第四条可以统一到规则4)
this._logics[4] = function(n,o){
if(n % o.number == 0){
return o.name;
}else{
return null;
}
}
//规则5
this._logics[5] = function(n,o){
if(n.toString().indexOf(o.number.toString())>=0){
return o.name;
}else{
return null;
}
} //2.调用核心执行接口
return this._exec();
};
fbw.html
<!DOCTYPE html>
<html>
<head>
<title>FizzBuzzWhizz - By YangYuan</title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
</head>
<body>
<!-- 结果列表 -->
<textarea id="fbwText" rows="30" cols="20"></textarea> <script src="js/fbw.js"></script>
<script>
//实例化
var f = new fbw(100,
[{
//特殊数
number: 3,
//特殊数代表的名称
name: "Fizz",
//规则列表,如果前边的规则一旦匹配,将忽略后边的规则
rules: [5,4]
},{
number: 5,
name: "Buzz",
rules: [4]
},{
number: 7,
name: "Whizz",
rules: [4]
}]
); //获取结果
var list = f.getFBW(); //显示到页面
for(var i in list){
document.getElementById("fbwText").value =
document.getElementById("fbwText").value +
"\n" +
list[i];
}
</script>
</body>
</html>
运行效果:
博客里看的不爽,可以直接打包下载:下载地址
拉勾网ThoughtWorks面试题代码实现的更多相关文章
- 一行代码搞定ThoughtWorks面试题
今天在微博看到一道有趣的题目.作为python的脑残粉,自然手痒. 题目在这里. FizzBuzzWhizz 你是一名体育老师.在某次课距离下课还有五分钟时,你决定搞一个游戏.此时有100名学生在上课 ...
- thoughtworks面试题分析与解答
题目描述 A squad of robotic rovers are to be landed by NASA on a plateau on Mars. This plateau, which is ...
- Java 面试题代码类收集
long temp=(int)3.9; System.out.println(temp); temp%=2; System.out.println(temp); 3 1 Java里面类的方法名可以与类 ...
- 2019 DevOps 必备面试题——代码版本控制篇
原文地址:https://medium.com/edureka/devops-interview-questions-e91a4e6ecbf3 原文作者:Saurabh Kulshrestha 翻译君 ...
- Java面试题代码篇
1.统计字符串中的各种字符的个数并对其排序 package JavaMianSiTest; public class TongJIZiFu { public static void main(Stri ...
- ThoughtWorks Merchant's Guide To The Galaxy
ThoughtWorks笔试题之Merchant's Guide To The Galaxy解析 一.背景 在某网站上看到ThoughtWorks在武汉招人,待遇在本地还算不错,就投递了简历.第二天H ...
- 设计模式之模板方法模式&&迪米特法则(代码Objective-C展示)
模板方法模式 模板方法模式:定义一个操作中的算法骨架,而将一些步骤延迟到子类中.模板方法使得子类可以在不改变一个算法的结构即可重定义该算法的某些特定步骤. 比如说,小时候数学老师的随堂检测,都是在黑板 ...
- .NET面试题(三)
第1讲:面试前期准备 1.了解相关技术职务需要的技术人才 2.准备一份出色的个人简历 第2讲:面试前期准备 ...
- 常见面试题整理--Python概念篇
希望此文可以长期更新并作为一篇Python的面试宝典.每一道题目都附有详细解答,以及更加详细的回答链接.此篇是概念篇,下一篇会更新面试题代码篇. (一).这两个参数是什么意思:*args,**kwar ...
随机推荐
- 更好更快更高效解析JSON说明
现在来一个实例解析类,直接就把解析JSON到QVariant去了.唯一不足的是没有搞错误处理,具体方法也请各位自行参考json-c的发行文档,这样比较方便叙述,STL或者Boost我都没有认真接触过, ...
- Asp.net using Oracle.DataAccess.dll access oracle 11g 64bit & x86
使用.net访问oracle数据库时一般需要在机器上安装instantclient才能正常连接. 下面介绍一种不用安装instantclient直接引用dll就用.net能连接oracle数据库的方法 ...
- jquery table 拼接集合
1html: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <ti ...
- scala学习心得3
在scala中可以定义函数字面量参数,定义方式如下:
- JAVA课程实验报告 实验五 Java网络编程及安全
北京电子科技学院(BESTI) 实 验 报 告 课程:Java程序设计 班级:1353 姓名:韩玉琪 学号:20135317 成绩: 指导教师:娄嘉 ...
- 点亮一个led灯
/********************************* 代码功能:点亮一个led灯 使用函数: pinMode(引脚号,模式); digitalWrite(引脚号,电平状态); //默认 ...
- mysql学习(二)
(1)存储过程:存储过程是SQL语句和控制语句的预编译集合,以一个名称存储并作为一个单元处理: (2)存储过程优点:增强SQL语句的功能和灵活性,实现较快的执行速度,减少网络流量: (3)存储过程结构 ...
- golang--gopher北京大会(1)
大会感想:牛人真的很能写代码,实现很多功能,而且开源的精品越多,影响力越大,越能过上dream life.比如beego的作者,去了America,进入了Apple.另外,精英们特点是表达能力很强,也 ...
- node.js 基础学习笔记2
Module和Package是Node.js最重要的支柱. Node.j 提供require函数来调用其他模块,而且模块都是基于文件.模块和包区别是透明的,因此常常不作区分. 1.模块和文件一一对应. ...
- SQL获取所有数据库名、表名、储存过程以及参数列表
SQL获取所有数据库名.表名.储存过程以及参数列表 1.获取所有用户名:SELECT name FROM Sysusers where status='2' and islogin='1'islogi ...