蓝桥杯 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
相关推荐
曦月逸霜6 分钟前
第十七次CCF-CSP算法(含C++源码)
开发语言·数据结构·c++·算法
single-tracking20 分钟前
关于vector、queue、list哪边是front、哪边是back,增加、删除元素操作
c++
患得患失94934 分钟前
【算法】力扣体系分类
算法·leetcode·分类
Moutai码农35 分钟前
机器学习算法-sklearn源起
算法·机器学习·sklearn
油泼辣子多加1 小时前
【风控】行为评分卡(B卡)模型
算法·金融·集成学习
走过冬季1 小时前
Java常用数据结构底层实现原理及应用场景
java·开发语言·数据结构
XIMCoCo1 小时前
C++ 实现二叉树的后序遍历与中序遍历构建及层次遍历输出
java·开发语言·c++
会编程的加缪1 小时前
算法学习——从零实现循环神经网络
rnn·深度学习·学习·算法·序列数据
dd向上2 小时前
Windows 平台 TCP 通信开发指南
c++·windows·网络协议·tcp/ip
0x7CF5 小时前
SetThrowSegvLongjmpSEHFilter错误和myFuncInitialize 崩溃
java·linux·算法