欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 编程资源 > 编程问答 >内容正文

编程问答

leetcode412. Fizz Buzz

发布时间:2023/12/13 编程问答 43 豆豆
生活随笔 收集整理的这篇文章主要介绍了 leetcode412. Fizz Buzz 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

写一个程序,输出从 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判断即可,这样可以解决更泛化的问题。

 

总结

以上是生活随笔为你收集整理的leetcode412. Fizz Buzz的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。