LintCode-9. Fizz Buzz 問題
阿新 • • 發佈:2019-02-14
題目描述
給你一個整數n. 從 1 到 n 按照下面的規則列印每個數:
- 如果這個數被3整除,列印fizz.
- 如果這個數被5整除,列印buzz.
- 如果這個數能同時被3和5整除,列印fizz buzz.
樣例
比如 n = 15, 返回一個字串陣列:
[
“1”, “2”, “fizz”,
“4”, “buzz”, “fizz”,
“7”, “8”, “fizz”,
“buzz”, “11”, “fizz”,
“13”, “14”, “fizz buzz”
]
挑戰
Can you do it with only one if statement?
分析
這道題其實就是簡單的條件語句使用,只不過這裡需要用到一個”int”型別轉”string”型的函式”to_string”。
程式碼
class Solution {
public:
/*
* @param n: An integer
* @return: A list of strings.
*/
vector<string> fizzBuzz(int n) {
// write your code here
vector<string> str(n);
for (int i = 1; i < n + 1; i++) {
if(i % 3 == 0 && i % 5 == 0) {
str[i - 1] = "fizz buzz";
} else if(i % 3 == 0) {
str[i - 1] = "fizz";a
} else if(i % 5 == 0) {
str[i - 1] = "buzz";
} else {
str[i - 1 ] = to_string(i);
}
}
return str;
}
};
接下來考慮挑戰的要求,不過我實在是想不出來如何只用一個”if”就可以完成要求,於是去網上查了一下發現用C++是實現不了的,只能用python寫,於是請教了群神,程式碼如下:
class Solution:
"""
@param: n: An integer
@return: A list of strings.
"""
def fizzBuzz(self, n):
# write your code here
return [' '.join([w + 'zz' for m, w in {3:'fi',5:'bu'}.items()if x % m < 1])or str(x) for x in range(1, n + 1)]
總結
python牛*