leetcode412. Fizz Buzz
【摘要】 写一个程序,输出从 1 到 n 数字的字符串表示。
1. 如果 n 是3的倍数,输出“Fizz”;
2. 如果 n 是5的倍数,输出“Buzz”;
3.如果 n 同时是3和5的倍数,输出 “FizzBuzz”。
示例:
n = 15,
返回: [ "1", &nb...
写一个程序,输出从 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判断即可,这样可以解决更泛化的问题。
文章来源: fantianzuo.blog.csdn.net,作者:兔老大RabbitMQ,版权归原作者所有,如需转载,请联系作者。
原文链接:fantianzuo.blog.csdn.net/article/details/106444336
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)