1. 程式人生 > >LintCode-9. Fizz Buzz 問題

LintCode-9. Fizz Buzz 問題

題目描述

給你一個整數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牛*