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