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);

一行解决。

相关推荐
bush4几秒前
嵌入式linux学习记录二
linux·运维·学习
Omics Pro21 分钟前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言
voidmort29 分钟前
3. 微调(Fine-tuning)与强化学习(RL)的核心思想
python·深度学习·算法
Bluetooth7301 小时前
c语言一维数组
c语言
人道领域1 小时前
【LeetCode刷题日记】669.修剪二叉搜索树
开发语言·python·算法
元气少女小圆丶2 小时前
SenseGlove Nova 2+Unity开发笔记1
笔记·学习·unity
QiLinkOS2 小时前
【从实验室到商业战场:发明专利如何重塑科技与企业的共生生态】
大数据·c语言·数据结构·c++·人工智能·单片机·算法
nashane2 小时前
HarmonyOS 6学习:应用退出动画优化实战——从“闪退“到优雅退出的完美蜕变
学习·华为·harmonyos
Irissgwe2 小时前
c++11(lambda表达式与包装器、线程库)
c++·c++11·lambda表达式·线程库·包装器·互斥量库·条件变量库
小白兔奶糖ovo3 小时前
【Leetcode】231. 2的幂
linux·算法·leetcode