PAT 字符串压缩与解压 20分 知识点:模拟

题目:1078 字符串压缩与解压 - PAT (Basic Level) Practice (中文) (pintia.cn)

解析:78_哔哩哔哩_bilibili

刚开始先读一个字符,根据这个字符是'C'还是'D'来决定是压缩还是解压缩。

我们先写'C'的逻辑:

这里我们用逆向思维,先让t++,然后我们去遍历给定的字符串,如果S[i]和S[i+1]不相等,这个时候就该停止t++了,并且要把t置空。

然后这个时候我们用一个空字符串+t+s[i] (得到的就是压缩的字符串)

但是我们发现结果如下:

Debug:

当遇到的字符相同个数是1的时候我们应该直接加这个字符串而不应该把'1'也加上。

Debug:

当i在最后一位的时候,没有s[i+1]进行比较了,我们应该直接把s[i]加上:

写'D'的逻辑:

Debug:

单个的字符我们没有加上:

修改:

code

js 复制代码
#include<bits/stdc++.h>
using namespace std;

string f1(string s)
{
    string ans;
    //逆向思维
    //首先让t++,然后遍历一下字符串,判断如果遇到两个不相同的停止t++
    int t=0;
    for(int i=0;i<s.size();i++)
    {
        t++;
        if(i+1!=s.size()&&s[i]!=s[i+1]||i+1==s.size())
        {
            if(t==1)ans+=s[i];
            else ans+=to_string(t)+s[i];
            t=0; 
        }
    }
return ans;
}

string f2(string s)
{
string ans;

for(int i=0;i<s.size();i++)
{
    if(isdigit(s[i]))
    {  int index=0,count=0;
         for(int j=i;j<s.size();j++)
         {
               count=count*10+s[j]-'0';
               if(s[j+1]>'9'||s[j+1]<'0') 
               {
                  index=j+1;
                   break;
               }
         }
           for(int k=1;k<=count;k++)
           {
               ans+=s[index];
               i=index;
           } 
     
    }
     else 
        ans+=s[i];
  
}
return ans;
}
int main()
{

    char op;cin>>op;getchar();
    if(op=='C')
    {
        //压缩
        string s1;getline(cin,s1);
       cout<< f1(s1);
    }
    if(op=='D')
    {
       string s1;getline(cin,s1);
       cout<< f2(s1);
    }
    return 0;
}
相关推荐
RTC老炮14 分钟前
webrtc弱网-RobustThroughputEstimator源码分析与算法原理
网络·算法·webrtc
听风吹等浪起30 分钟前
分类算法-逻辑回归
人工智能·算法·机器学习
敲代码的嘎仔32 分钟前
JavaWeb零基础学习Day2——JS & Vue
java·开发语言·前端·javascript·数据结构·学习·算法
yacolex1 小时前
3.3_数据结构和算法复习-栈
数据结构·算法
茉莉玫瑰花茶1 小时前
动态规划 - 两个数组的 dp 问题
算法·动态规划
微笑尅乐1 小时前
从暴力到滑动窗口全解析——力扣8. 字符串转换整数 (atoi)
算法·leetcode·职场和发展
火花怪怪2 小时前
LaMer结晶动力学模型
算法
legendary_bruce2 小时前
【22.2 增强决策树】
算法·决策树·机器学习
老马啸西风3 小时前
力扣 LC27. 移除元素 remove-element
算法·面试·github
数智顾问3 小时前
中秋特别篇:使用QtOpenGL和着色器绘制星空与满月——从基础框架到光影渲染
算法