本文介绍: 实现的是经典的FizzBuzz问题,即对从1到n的每个整数进行如下操作:如果该数能被3整除,就在答案添加“Fizz”;如果该数能被5整除,就在答案添加“Buzz”;如果该数能同时被3和5整除,就在答案添加“FizzBuzz”。如果都不能,就将该数本身添加答案中。各个整数的 Fizz Buzz 表示,并用字符串数组

1、题目

给你一个整数 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 (以字符串形式)如果上述条件全不满足。

示例 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 <= n <= 104

 

2、解析

实现的是经典的FizzBuzz问题,即对从1到n的每个整数进行如下操作:如果该数能被3整除,就在答案添加“Fizz”;如果该数能被5整除,就在答案中添加”Buzz”;如果该数能同时被3和5整除,就在答案中添加”FizzBuzz”。如果都不能,就将该数本身添加到答案中。

  1. 创建一个名为answer的空列表用于存储结果
  2. 使用for循环遍历从1到n的每个整数(在Python中,range(n)生成一个从0到n-1的整数序列)。
  3. 在循环中,首先检查当前整数(i+1)是否能被15整除(i+1)%15==0)。如果能,就在answer`中添加字符串“FizzBuzz”,然后跳过本次循环,准备处理下一个整数
  4. 如果不能被15整除,就检查当前整数是否能被3整除((i+1)%3==0)。如果能,就在answer`中添加字符串“Fizz”,然后跳过本次循环。
  5. 如果既不能被15整除,也不能被3整除,就检查当前的整数是否能被5整除((i+1)%5==0)。如果能,就在answer`中添加字符串“Buzz”,然后跳过本次循环。
  6. 如果以上三个条件都不满足,就说明当前的整数既不能被3整除,也不能被5整除,更不能被15整除。这时,就将该整数转换字符串,并添加到answer中。
  7. 循环结束后,返回存储结果answer列表

3、python代码

class Solution:
    def fizzBuzz(self, n: int) -&gt; list[str]:
        answer=[]
        for i in range(n):
            if (i+1)%15==0:
                answer.append("FizzBuzz")
            elif (i+1)%3==0:
                answer.append("Fizz" )
            elif (i+1)%5==0:
                answer.append("Buzz")
            else:
                answer.append(str(i+1))
        return answer

 4、运行结果

 

原文地址:https://blog.csdn.net/Python_1981/article/details/134679561

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。

如若转载,请注明出处:http://www.7code.cn/show_4389.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注