一条有趣的前端面试题(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")

你可能感兴趣的:(一条有趣的前端面试题(2))