关于leetcode:Golang力扣Leetcode初级算法数学Fizz-Buzz

53次阅读

共计 894 个字符,预计需要花费 3 分钟才能阅读完成。

题目
给你一个整数 n,找出从 1 到 n 各个整数的 Fizz Buzz 示意,并用字符串数组 answer(下标从 1 开始)返回后果,其中:
    answer[i] == “FizzBuzz” 如果 i 同时是 3 和 5 的倍数。
    answer[i] == “Fizz” 如果 i 是 3 的倍数。
    answer[i] == “Buzz” 如果 i 是 5 的倍数。
    answer[i] == i(以字符串模式)如果上述条件全不满足。

链接:力扣 Leetcode—高级算法—数学—Fizz Buzz.

示例 1

输出:n = 3
输入:[“1″,”2″,”Fizz”]

示例 2

输出:n = 5
输入:[“1″,”2″,”Fizz”,”4″,”Buzz”]

示例 3

输出:n = 15
输入:[“1″,”2″,”Fizz”,”4″,”Buzz”,”Fizz”,”7″,”8″,”Fizz”,”Buzz”,”11″,”Fizz”,”13″,”14″,”FizzBuzz”]

标签:数学、字符串、模仿

思路 :定义一个字符串数组,从 1 开始遍历,用 append 在数组后顺次增加字符串。遇到同时是 3 和 5 的倍数,增加字符串 FizzBuzz;遇到是 3 的倍数,增加字符串 Fizz;遇到是 5 的倍数,增加字符串 Buzz;其余就把 int 类型转换为 string 类型,要应用到 strconve.Itoa(i) 函数

次要 Go 代码如下:

package main

import (
    "fmt"
    "strconv"
)

func fizzBuzz(n int) []string {var list []string
    for i := 1; i <= n; i++ {
        if i%3 == 0 && i%5 == 0 {list = append(list, "FizzBuzz")
        } else if i%3 == 0 {list = append(list, "Fizz")
        } else if i%5 == 0 {list = append(list, "Buzz")
        } else {list = append(list, strconv.Itoa(i))
        }
    }
    return list
}

func main() {
    var a int
    fmt.Scanf("%d", &a)
    fmt.Println(fizzBuzz(a))
}

提交截图

正文完
 0