leetcode412. Fizz Buzz
生活随笔
收集整理的這篇文章主要介紹了
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的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 好莱坞大片轮番轰炸 20部值得期待的科幻
- 下一篇: e4a服务器文件,e4a链接网站服务器