leetcode412. Fizz Buzz

举报
兔老大 发表于 2021/04/22 01:08:40 2021/04/22
【摘要】 写一个程序,输出从 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"
]

思路:

直接模拟


  
  1. class Solution {
  2. public List<String> fizzBuzz(int n) {
  3. List<String> ans = new ArrayList<String>();
  4. for (int num = 1; num <= n; num++) {
  5. if ((num % 3 == 0) && (num % 5 == 0)) {
  6. ans.add("FizzBuzz");
  7. } else if (num % 3 == 0) {
  8. ans.add("Fizz");
  9. } else if (num % 5 == 0) {
  10. ans.add("Buzz");
  11. } else {
  12. ans.add(Integer.toString(num));
  13. }
  14. }
  15. return ans;
  16. }
  17. }

思路2:

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

思路3:

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

 

文章来源: fantianzuo.blog.csdn.net,作者:兔老大RabbitMQ,版权归原作者所有,如需转载,请联系作者。

原文链接:fantianzuo.blog.csdn.net/article/details/106444336

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。