C++学习记录-旧题新做-字符串压缩

旧题记录帖:https://blog.csdn.net/chamao_/article/details/143305269?fromshare=blogdetail&sharetype=blogdetail&sharerId=143305269&sharerefer=PC&sharesource=chamao_&sharefrom=from_link

c++解法:

cpp 复制代码
class Solution {
public:
    string compressString(string S) {
        if(S.empty()) return S;
        std::string s;
        s.reserve(S.length() * 2); // .reserve()能提前预留空间
        int index = 0;
        int i = 0;
        while(i < S.length()) {
            char currentChar = S[i];
            int count = 0;
            while(i < S.length() && S[i] == currentChar) {
                count++;
                i++;
            }
            // 追加字符和数字
            s += currentChar;
            s += std::to_string(count);
        }
        if(s.length() >= S.length()) {
            return S;
        }
        return s;
    }
};

1. 为什么用.reserve() 而不是 .resize()?

  • reserve(n):只是提前分配"容量",不改变字符串长度

  • resize(n):改变字符串的"长度",并用 '\0' 填充新增字符

在我的压缩字符串构造过程中,我并不希望字符串一开始就变长 ,所以要用 reserve

2. std::to_string 是什么?

to_string() 用来把"数字类型"转换为 std::string

例如:

cpp 复制代码
std::string s = std::to_string(123);   // "123"

std::string s = std::to_string(123); // "123"

这是 C++11 新增的功能。


3. to_string 支持哪些类型?

它支持 基本数字类型

类型 示例
int std::to_string(10)
long std::to_string(123L)
long long std::to_string(123LL)
unsigned std::to_string(10u)
unsigned long std::to_string(10ul)
unsigned long long std::to_string(10ull)
float std::to_string(3.14f)
double std::to_string(3.14)
long double std::to_string(3.14L)

📌 注意:不支持 char 和 bool!

如果你写:

cpp 复制代码
std::to_string('A');

std::to_string('A');

它会把 'A' 当做数字 65 转换成 "65"


4. 为什么 C++ 推荐用 to_string 而不是 sprintf

因为它更安全、更直观:

✔ 不需要格式化字符串

sprintf 写错一个 %d%s 会崩溃。

to_string 不会。

✔ 无需关心缓冲区大小

sprintf 必须让你自己保证 buffer 足够大。

to_string 会自动管理内存,完全不会溢出。

对比:

cpp 复制代码
char buf[20];
sprintf(buf, "%d", num);   // 危险,需检查大小

char buf[20]; sprintf(buf, "%d", num); // 危险,需检查大小

C++ 写法:

cpp 复制代码
std::string s = std::to_string(num);

std::string s = std::to_string(num);

一行解决。

相关推荐
TracyCoder1232 分钟前
LeetCode Hot100(28/100)——104. 二叉树的最大深度
算法·leetcode
sensen_kiss4 分钟前
Jupter Notebook 使用教程
大数据·人工智能·python·学习·数据分析
执着25913 分钟前
力扣hot100 - 101、对称二叉树
数据结构·算法·leetcode
多恩Stone15 分钟前
【3D-AICG 系列-1】Trellis v1 和 Trellis v2 的区别和改进
人工智能·pytorch·python·算法·3d·aigc
三月微暖寻春笋16 分钟前
【和春笋一起学C++】(五十九)派生类和基类之间的关系
c++·基类·派生类·关系
mit6.82421 分钟前
模运算|z函数 字符串匹配
算法
阿豪只会阿巴23 分钟前
【吃饭香系列】二周目|代码随想录算法训练营第七天|454.四数相加II |383. 赎金信 |15. 三数之和 |18. 四数之和
算法
狂奔蜗牛飙车24 分钟前
Python学习之路-Python3 迭代器与生成器学习详解
开发语言·python·学习·#python学习笔记·python迭代器生成器
进击的小头24 分钟前
设计模式与C语言高级特性的结合
c语言·设计模式
小O的算法实验室26 分钟前
2025年COR SCI2区,考虑风场影响的无人机搜救覆盖路径规划精确界算法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进