一条有趣的前端面试题(2)

在网上看到这么一条十分有趣的题目:

你是一名体育老师,在某次课距离下课还有五分钟时,你决定搞一个游戏。此时有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名学生应该报数的数或单词

看到这道题,我的第一反应想到的就是%取模,for循环,思路还算是清晰吧。那么我们再进行细致点的分析,条件上有3个点,

  1. 只是一个特殊数的倍数
  2. 两个或者三个特殊数的倍数
  3. 包涵第一个特殊数的特殊情况!

那么我们首先要做的是for一个1~100来吧,然后,判断每个数字,是否匹配这几个条件。

function num() {
    var arr = [3, 5, 7];
    var str = ["Fizz", "Buzz", "Whizz"];
    for (var i = 1; i <= 100; i++) {
        var strr;
        if (i % arr[0] !== 0 && i % arr[1] !== 0 && i % arr[2] !== 0) {
            strr = i;
        }
        if (i % arr[1] == 0) {
            strr += "Buzz";
        }
        if (i % arr[1] == 0) {
            strr += "Buzz";
        }
        if (i % arr[2] == 0) {
            strr += "Whizz";
        }
    }
}

写到这里的时候我陷入的瓶颈,好多的判断啊,很麻烦,左思右想的,突然想起了,三元运算符,一下子,就通了。

//a为1~100之间的数
//b为特殊数
//c为为特殊数对应的输出
//这个方法是 判断是否为特殊数
function str(a, b, c) {
    return a % b === 0 ? c : "";
}

function num() {
    var arr = [3, 5, 7];
    var str = ["Fizz", "Buzz", "Whizz"];
    for (var i = 1; i <= 100; i++) {
        //因为条件2 说明遇到同时是两个或者3个特殊数的倍数时,需要叠加
        var str = str(i, arr[0], str[0]) + str(i, arr[1], str[1]) + str(i, arr[2], str[2]);
    }
}

此时,变量str的值,不是为“”,就是为特殊字符。接下来,需要做出判断,当str=“”时,我们希望输出的是i。另外,还有条件3 的没有进行判断。

//a为1~100之间的数
//b为特殊数
//c为为特殊数对应的输出
//这个方法是 判断是否为特殊数
function Rstr(a, b, c) {
    return a % b === 0 ? c : "";
}

function num() {
    var arr = [3, 5, 7];
    var str = ["Fizz", "Buzz", "Whizz"];
    for (var i = 1; i <= 100; i++) {
        //因为条件2 说明遇到同时是两个或者3个特殊数的倍数时,需要叠加
        var str2 = Rstr(i, arr[0], str[0]) + Rstr(i, arr[1], str[1]) + Rstr(i, arr[2], str[2]);
        var res;
        if ((i + "").indexOf(arr[0]) !== -1) {
            res = str[0];
        } else if (str2 == "") {
            res = i;
        } else {
            res = str2;
        }
        console.log(res)
    }
}

很好,输出的就是我们要的结果。再进一步的优化下代码!运用的还是三元运算符。最终代码为:

//a为1~100之间的数
//b为特殊数
//c为为特殊数对应的输出
//这个方法是 判断是否为特殊数
function Rstr(a, b, c) {
    return a % b === 0 ? c : "";
}
//x,y,z为特殊数
function num(x, y, z) {
    for (var i = 1; i <= 100; i++) {
        //因为条件2 说明遇到同时是两个或者3个特殊数的倍数时,需要叠加
        var str2 = Rstr(i, x, "Fizz") + Rstr(i, y, "Buzz") + Rstr(i, z, "Whizz");
        console.log((i + "").indexOf(x) !== -1 ? "Fizz" : str2 !== "" ? str2 : i)
    }
};
num("3", "5", "7")
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 即使水墨丹青,何以绘出半妆佳人。 Scala是一门优雅而又复杂的程序设计语言,初学者很容易陷入细节而迷失方向。这也...
    刘光聪阅读 3,047评论 4 9
  • 序言 控制复杂性是计算机编程的本质。—— Brian Kernighan 有一次给某团队培训TDD时,团队选择的语...
    _张晓龙_阅读 1,282评论 0 4
  • 经过一段时间的筹备,我们的实验室现在要开始纳新啦~ 当然我们也是要经过面试的呀亲爱的们 你们期待已久的面试题出炉啦...
    977777阅读 1,187评论 0 0
  • FizzBuzzWhizz 你是一名体育老师,在某次课距离下课还有五分钟时,你决定搞一个游戏。此时有100名学生在...
    豹纹奶嘴草上飞阅读 383评论 0 1
  • 问题 你是一名体育老师,在某次课距离下课还有五分钟时,你决定搞一个游戏。此时有100名学生在上课。游戏的规则是: ...
    davidhuangdw阅读 750评论 0 1