题目:
给你一个整数 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))
}
提交截图: