力扣第3刷-Fizz Buzz

简介: 力扣第3刷-Fizz Buzz

Example 3

Fizz Buzz

题目概述:给你一个整数 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"]

 

解题思路:根据题意,根据i(1≤i≤n)是否可以被“3或5”、“仅3”“仅5”整除,对应不同的分支,在不同的分支内给集合添加不同的元素。

解题步骤:

1. 定义集合,代表要返回的字符串集合

2. 定义for循环,遍历1-n之间的所有整数。

3. 首先判断i是否能被3或5整除(被15整除),若可以,则在集合中添加"FizzBuzz",否则继续判断,依次判断是否能被3整除、5整除,对应的操作为分别在集合中添加"Fizz"、"Fizz",若以上条件均不满足,则将数字i转换为String型,添加到集合中。

4. 循环结束后,将集合返回。

 

示例代码如下:

publicclassFizzBuzz {
/*** 给你一个整数 n ,找出从 1 到 n 各个整数的 Fizz Buzz 表示,并用字符串数组 answer(下标从 1 开始)返回结果,其中:* <p>* answer[i] == "FizzBuzz" 如果 i 同时是 3 和 5 的倍数。* answer[i] == "Fizz" 如果 i 是 3 的倍数。* answer[i] == "Buzz" 如果 i 是 5 的倍数。* answer[i] == i (以字符串形式)如果上述条件全不满足。*  * <p>* 示例 1:* <p>* 输入:n = 3* 输出:["1","2","Fizz"]* 示例 2:* <p>* 输入:n = 5* 输出:["1","2","Fizz","4","Buzz"]* 示例 3:* <p>* 输入:n = 15* 输出:["1","2","Fizz","4","Buzz","Fizz","7","8","Fizz","Buzz","11","Fizz","13","14","FizzBuzz"]* <p>* 来源:力扣(LeetCode)* 链接:https://leetcode.cn/problems/fizz-buzz*/publicstaticvoidmain(String[] args) {
FizzBuzzfb=newFizzBuzz();
System.out.println(fb.fizzBuzz(5)); // [1, 2, Fizz, 4, Buzz]    }
/*** 个人** @param n* @return*/publicList<String>fizzBuzz(intn) {
List<String>answer=newArrayList<>();
for (inti=1; i<=n; i++) {
if (i%15==0) answer.add("FizzBuzz");
elseif (i%3==0) answer.add("Fizz");
elseif (i%5==0) answer.add("Buzz");
elseanswer.add(Integer.toString(i));
        }
returnanswer;
    }
/*** 官方* @param n* @return*//*    public List<String> fizzBuzz(int n) {List<String> answer = new ArrayList<String>();for (int i = 1; i <= n; i++) {StringBuffer sb = new StringBuffer();if (i % 3 == 0) {sb.append("Fizz");}if (i % 5 == 0) {sb.append("Buzz");}if (sb.length() == 0) {sb.append(i);}answer.add(sb.toString());}return answer;}*/}
相关文章
|
边缘计算 人工智能 运维
如何构建基于数字孪生的智慧全息路口
全息路口是基于数字孪生技术,将城市道路上的全要素进行数字化还原,进而为交通治理提供一体化解决措施,是为交通精细化治理而生的一款产品。
1858 0
如何构建基于数字孪生的智慧全息路口
|
8月前
|
人工智能 测试技术 定位技术
WorldScore:斯坦福开源世界生成模型评估新标杆:3000样本+九维指标,视频/4D/3D模型一网打尽
WorldScore是斯坦福大学提出的首个统一评估世界生成模型的基准测试,通过基于相机轨迹的布局规范和3000个多样化样本,全面评测生成内容的可控性、质量与动态性。
522 46
WorldScore:斯坦福开源世界生成模型评估新标杆:3000样本+九维指标,视频/4D/3D模型一网打尽
|
10月前
|
存储 人工智能 自然语言处理
AI 剧本生成与动画创作解决方案体验报告
AI 剧本生成与动画创作解决方案体验报告
461 40
|
10月前
|
机器学习/深度学习 计算机视觉
YOLOv11改进策略【注意力机制篇】| 2024 PPA 并行补丁感知注意模块,提高小目标关注度
YOLOv11改进策略【注意力机制篇】| 2024 PPA 并行补丁感知注意模块,提高小目标关注度
452 11
YOLOv11改进策略【注意力机制篇】| 2024 PPA 并行补丁感知注意模块,提高小目标关注度
|
10月前
|
人工智能 测试技术
LIMO:上海交大推出高效推理方法,仅需817条训练样本就能激活大语言模型的复杂推理能力
LIMO 是由上海交通大学推出的一种高效推理方法,通过极少量的高质量训练样本激活大语言模型的复杂推理能力。
434 11
|
10月前
|
数据可视化 安全 持续交付
敏捷方法大比拼:Scrum 适合你,还是 Kanban 更合适?
在数字化时代,企业面临项目管理的诸多挑战,如信息不透明、沟通低效等。Scrum 和 Kanban 作为敏捷管理方法,通过迭代优化和流程可视化提升协作效率与交付速度。Scrum 适合周期性迭代交付,强调短周期冲刺;Kanban 则适用于持续交付,强调任务流动性和灵活性。两者结合可形成 ScrumBan 模式,进一步优化任务处理。 对于数据安全要求高的企业,私有化部署工具(如板栗看板)确保数据自主可控、高安全性及定制化需求,保障业务连续性。选择合适的敏捷方法并结合私有化部署,能有效提升团队协作效率,助力企业在竞争中保持领先。
|
机器学习/深度学习 数据采集 供应链
使用Python实现智能食品销售预测的深度学习模型
使用Python实现智能食品销售预测的深度学习模型
277 3
|
前端开发 UED
长轮询(Long Polling)的缺点有哪些?
【10月更文挑战第8天】
435 2
物联网卡:带你快速了解物联网卡充值失败的原因
物联网卡充值失败可能由多种原因引起,下面是一些常见的原因及相应的操作建议,以帮助您解决问题:
|
传感器 人工智能 算法
探索人工智能与物联网的融合创新
随着科技的迅猛发展,人工智能(AI)和物联网(IoT)这两大技术正在逐渐深度融合,催生出一系列创新性应用。本文将探讨这一领域的技术原理、应用场景及其未来发展前景,旨在为读者提供全面而深入的理解。
990 2