蓝桥杯 3. 压缩字符串

压缩字符串

原题目链接

题目描述

实现一个算法来压缩一个字符串。压缩的要求如下:

  • 需要判断压缩能不能节省空间,仅在压缩后字符串比原字符串长度更短时进行压缩。
  • 压缩的格式是将连续相同字符替换为字符 + 数字形式,例如 "AAABCCDDDD" 变为 "A3BC2D4"

输入描述

  • 输入一行字符串,长度不超过 500。

输出描述

  • 输出一行。若输入的字符串可压缩,则输出压缩后的字符串,否则输出 NO

输入输出样例

输入

in 复制代码
AAABCCDDDD

输出

out 复制代码
A3BC2D4

c++代码

cpp 复制代码
#include<bits/stdc++.h>

using namespace std;

int main() {
    string str, ans;
    cin >> str;
    for (int i = 0; i < str.size();) {
        char a = str[i];
        int cont = 0;
        while(i + cont < str.size() && str[i + cont] == a) cont++;
        ans += a;
        if (cont > 1) ans += to_string(cont);
        i = i + cont;
    }
    if (ans != str) cout << ans;
    else cout << "NO";
    return 0;
}//by wqs
相关推荐
LWing65129 分钟前
算法基础学习|02归并排序——分治
c++·学习·算法
Normal Developer3 小时前
HotSpot的算法细节
java·jvm·算法
YuforiaCode8 小时前
第十六届蓝桥杯 2025 C/C++B组第一轮省赛 全部题解(未完结)
c语言·c++·蓝桥杯
lsnm8 小时前
【LINUX操作系统】线程操作
linux·jvm·c++·ubuntu·centos·gnu
杀神lwz8 小时前
数据结构和算法(八)--2-3查找树
数据结构
zhengtianzuo8 小时前
043-代码味道-循环依赖
c++
Tanecious.8 小时前
初阶数据结构--排序算法(全解析!!!)
数据结构·算法·排序算法
CoderCodingNo8 小时前
【GESP】C++三级练习 luogu-B2118 验证子串
开发语言·c++
hu_yuchen10 小时前
C++:Lambda表达式
开发语言·c++·算法