力扣第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;}*/}
相关文章
|
6月前
【Leetcode -412.Fizz Buzz -414.第三大的数】
【Leetcode -412.Fizz Buzz -414.第三大的数】
30 0
|
3月前
|
C++
Fizz Buzz(C++)
Fizz Buzz(C++)
28 0
力扣刷题记录——412. Fizz Buzz、414. 第三大的数、415. 字符串相加
力扣刷题记录——412. Fizz Buzz、414. 第三大的数、415. 字符串相加
力扣刷题记录——412. Fizz Buzz、414. 第三大的数、415. 字符串相加
LeetCode 412. Fizz Buzz
写一个程序,输出从 1 到 n 数字的字符串表示。
104 0
|
机器学习/深度学习 NoSQL Shell
力扣第29刷-反转字符串
力扣第29刷-反转字符串
力扣第29刷-反转字符串
Leetcode-Easy 412. Fizz Buzz
Leetcode-Easy 412. Fizz Buzz
67 0
Leetcode-Easy 412. Fizz Buzz