您的位置:首页 > 其它

LintCode-9. Fizz Buzz 问题

2018-01-23 19:12 375 查看

题目描述

给你一个整数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牛*
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: