leetcode412. Fizz Buzz

   日期:2020-06-05     浏览:176    评论:0    
核心提示:写一个程序,输出从1到n数字的字符串表示。1.如果n是3的倍数,输出“Fizz”;2.如果n是5的倍数,输出“Buzz”;3.如果n同时是3和5的倍数,输出“FizzBuzz”。示例:n=15,返回:[1,2,Fizz,4,Buzz,Fizz,7,8,Fizz,Buzz,11,Fizz,...

写一个程序,输出从 1 到 n 数字的字符串表示。

1. 如果 n 是3的倍数,输出“Fizz”;

2. 如果 n 是5的倍数,输出“Buzz”;

3.如果 n 同时是3和5的倍数,输出 “FizzBuzz”。

示例:

n = 15,

返回:
[
    "1",
    "2",
    "Fizz",
    "4",
    "Buzz",
    "Fizz",
    "7",
    "8",
    "Fizz",
    "Buzz",
    "11",
    "Fizz",
    "13",
    "14",
    "FizzBuzz"
]

思路:

直接模拟

class Solution {
  public List<String> fizzBuzz(int n) {
    List<String> ans = new ArrayList<String>();
    for (int num = 1; num <= n; num++) {
      if ((num % 3 == 0) && (num % 5 == 0)) {
        ans.add("FizzBuzz");
      } else if (num % 3 == 0) {
        ans.add("Fizz");
      } else if (num % 5 == 0) {
        ans.add("Buzz");
      } else {
        ans.add(Integer.toString(num));
      }
    }
    return ans;
  }
}

思路2:

可以把每个条件判断一次,把对应的字符串加起来。这样就不用八每种条件组合想到,更加优雅便捷。

思路3:

条件和答案的映射其实就是kv的关系,一种条件对应一段答案(本题就是字符串),所以,可以把所有关系放到一个map内,遇到每个数字都遍历map判断即可,这样可以解决更泛化的问题。

 

 
打赏
 本文转载自:网络 
所有权利归属于原作者,如文章来源标示错误或侵犯了您的权利请联系微信13520258486
更多>最近资讯中心
更多>最新资讯中心
0相关评论

推荐图文
推荐资讯中心
点击排行
最新信息
新手指南
采购商服务
供应商服务
交易安全
关注我们
手机网站:
新浪微博:
微信关注:

13520258486

周一至周五 9:00-18:00
(其他时间联系在线客服)

24小时在线客服