场景需求:
给你一个整数 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 (以字符串形式)如果上述条件全不满足。
示例 :
输入:n = 15
输出:["1","2","Fizz","4","Buzz","Fizz","7","8","Fizz","Buzz","11","Fizz","13","14","FizzBuzz"]
初版实现:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
func fizzBuzz(n int) []string {
var res []string
for i := 1; i <= n; i++ {
if i%3 == 0 && i%5 == 0 {
res = append(res, "FizzBuzz")
continue
}
if i%3 == 0 {
res = append(res, "Fizz")
continue
}
if i%5 == 0 {
res = append(res, "Buzz")
continue
}
res = append(res, fmt.Sprintf("%d", i))
}
return res
}
|
优化版本:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
// 优化结果:执行时间快一倍
// 优化思路:减少内存分配,减少重复的判断和赋值
func fizzBuzz(n int) []string {
res := make([]string, n)
for i := 1; i <= n; i++ {
if i%3 == 0 {
res[i-1] += "Fizz"
}
if i%5 == 0 {
res[i-1] += "Buzz"
}
if res[i-1] == "" {
res[i-1] = strconv.Itoa(i)
}
}
return res
}
|