共计 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))
}
提交截图:
正文完