【LeetCode】 412. Fizz Buzz

题目链接


文章目录

    • [Python3 【O(n) O(1)】](#Python3 【O(n) O(1)】)
    • C++
      • [.emplace_back() 【C++ 11 之后】](#.emplace_back() 【C++ 11 之后】)

Python3 【O(n) O(1)】

初始版本

python 复制代码
class Solution:
    def fizzBuzz(self, n: int) -> List[str]:
        ans = []
        for i in range(1, n+1):
            if i % 5 == 0 and i % 3 == 0:
                ans.append("FizzBuzz")
            elif i % 3 == 0:
                ans.append("Fizz")  
            elif i % 5 == 0:
                ans.append("Buzz")
            else:
                ans.append(str(i))

        return ans 

第一种情况 就是两种情况同时满足,两个都输出

官方题解的 逻辑也可以

  • 需要注意 顺序
python 复制代码
class Solution:
    def fizzBuzz(self, n: int) -> List[str]:
        ans = []
        for i in range(1, n+1):
            # 拼接 输出的 字符串 s
            s = ""
            if i % 3 == 0:
                s += "Fizz"
            if i % 5 == 0:
                s += "Buzz"
            if s == "": # 既不是3的倍数,也不是5的倍数
                s = str(i)  
            ans.append(s)
        return ans 

C++

cpp 复制代码
class Solution {
public:
    vector<string> fizzBuzz(int n) {
        vector<string> ans;
        for (int i = 1; i <= n; ++i){
            string s;
            if (i % 3 == 0){
                s += "Fizz";
            }
            if (i % 5 == 0){
                s += "Buzz";
            }
            if (s.size() == 0){
                s = to_string(i);
            }
            //ans.push_back(s);
            ans.emplace_back(s);  // 比 push_back 快
        }
        return ans;
    }
};

.emplace_back() 【C++ 11 之后】

在 C++11 之后,vector 容器中添加了新的方法emplace_back() ,和 push_back() 一样的是都是在容器末尾添加一个新的元素进去,不同的是 emplace_back() 在效率上相比较于 push_back() 有了一定的提升

emplace_back 将一个就地构造 的元素添加到向量末尾。

相关推荐
九德拉4 小时前
利用XPlaneConnect从X-Plane内读写数据
c++·飞行仿真·x-plane
_OP_CHEN5 小时前
C++进阶:(三)深度解析二叉搜索树原理及实现
开发语言·数据结构·c++·二叉树·二叉搜索树·键值对
郝学胜-神的一滴6 小时前
深入解析C++命令模式:设计原理与实际应用
开发语言·c++·程序人生·软件工程·命令模式
ShineSpark6 小时前
Crashpad介绍
c++·windows
苏纪云7 小时前
算法<C++>——双指针 | 滑动窗口
数据结构·c++·算法·双指针·滑动窗口
Brookty7 小时前
【算法】位运算| & ^ ~ -n n-1
学习·算法·leetcode·位运算
剪一朵云爱着7 小时前
力扣2560. 打家劫舍 IV
算法·leetcode
ouliten8 小时前
C++笔记:std::variant
开发语言·c++·笔记
Yupureki9 小时前
从零开始的C++学习生活 20:数据结构与STL复习课(4.4w字全解析)
c语言·数据结构·c++·学习·visual studio·1024程序员节
REDcker9 小时前
C++项目 OpenSSL 依赖最佳实践
开发语言·c++