zoukankan      html  css  js  c++  java
  • 白菜刷LeetCode记-412. Fizz Buzz

    今天是开始用JavaScript刷LeetCode的第二天。题目如下:

    题意是输出一个1到n的数组,遇到3的倍数用“Fizz”代替,遇到5的倍数用“Buzz”代替,遇到15的倍数则用“FizzBuzz”来代替。

    这题目比较简单呀,直接用if-else if-else的条件判断语句来完成不就好了嘛。于是便有如下答案:

     1 /**
     2  * @param {number} n
     3  * @return {string[]}
     4  */
     5 var fizzBuzz = function(n) {
     6     var arr = [];
     7     for(let i = 0; i < n; i++){
     8         if( (i+1)%3 == 0 && (i+1)%5 == 0){
     9             arr.push("FizzBuzz");
    10         }else if( (i+1)%3 == 0 ){
    11             arr.push("Fizz");
    12         }else if( (i+1)%5 == 0 ){
    13             arr.push("Buzz");
    14         }else{
    15             arr.push(String(i+1));
    16         }
    17     }
    18     
    19     return arr;
    20 };

    看着这些条件判断语句,想了想能否有更加简短的方法呢,或者说可不可以减少代码量来实现相同的功能呢?

    有的,可以用JavaScript的条件运算符,代码如下:

     1 /**
     2  * @param {number} n
     3  * @return {string[]}
     4  */
     5 var fizzBuzz = function(n) {
     6     var arr = [];
     7     for(let i = 0; i < n; i++){
     8         arr.push( (i+1)%15 == 0 ? "FizzBuzz" : ((i+1)%3 == 0 ? "Fizz" : ((i+1)%5 == 0 ? "Buzz" : String(i+1))));
     9     }
    10     
    11     return arr;
    12 };

    OK,今天就到这里吧!

  • 相关阅读:
    面试题21 包含min函数的栈
    面试题20 顺时针打印矩阵
    基于熵的方法计算query与docs相似度
    使用信息检索和深度学习方法的智能对话
    常用的激活函数
    spark实现smote近邻采样
    wide&deep用于ltr排序
    deepfm用于ltr排序
    lightgbm用于排序
    静态工厂方法+服务提供者框架模板
  • 原文地址:https://www.cnblogs.com/sssysukww/p/9517477.html
Copyright © 2011-2022 走看看