412.FizzBuzz

写一个程序,输出从 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<>();

HashMap<Integer, String> fizzBuzzDict = new HashMap<Integer, String>() {
{
put(3, "Fizz");
put(5, "Buzz");
}
};

for(int num=1; num<=n; num++){

String numAnsStr = "";

for( Integer key : fizzBuzzDict.keySet() ){
if ( num % key == 0 )
numAnsStr += fizzBuzzDict.get(key);
}

if ( "".equals(numAnsStr) )
numAnsStr += Integer.toString(num);

ans.add(numAnsStr);

}

return ans;
}
}

算法流程:
使用字典,字典的键存放相关的数字(本题中的3和5),对应的值存放相应的要说的话(Fizz或Buzz)。遍历长度为 n 的数组,其中再遍历字典的键,若数字能整除键,数组的相应位置就存放 “Fizz” 或 “Buzz”;若不能整除,数组的响应位置就存放该数字。

复杂度分析:
时间复杂度: O(N)
空间复杂度: O(1)

原题链接
官方题解

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值