• Codeforces Round #820 (Div. 3) B Decode String


    题意:

    来更一道水的不能再水的模拟....

    题意:

    有一个从字符翻译到数字的映射规则:

    如果字符的数字只有个位数,就直接翻译

    如果字符的数字是两位数,就翻译后在数字末尾加0

    现在给你一串数字,让你还原这个字符串

    思路:

    模拟:

    有两个做法:一个是倒序遍历,遇到0就把0前两个数字变成字符就好了

    另一个是分类讨论,4个4个遍历,当且仅当第3个数是0且第4个数不是0且没越界时映射两位数,否则就映射一位数

    Code:

    1. #include
    2. using namespace std;
    3. int n;
    4. string s,ans;
    5. void solve(){
    6. ans.clear();
    7. cin>>n>>s;
    8. s='?'+s;
    9. for(int i=1;i<=n;i++){
    10. if(s[i+2]=='0'&&i+2<=n&&(s[i+3]!='0'||i+3>n)){
    11. int tmp=(s[i]-'0')*10+s[i+1]-'0';
    12. ans+=tmp+'a'-1;
    13. i+=2;
    14. }else{
    15. int tmp=s[i]-'0';
    16. ans+=tmp+'a'-1;
    17. }
    18. }
    19. cout<
    20. }
    21. int main(){
    22. ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
    23. int T;
    24. cin>>T;
    25. while(T--) solve();
    26. return 0;
    27. }

    总结:我们是怎么模拟的?

    首先,我们要确定我们的业务逻辑,然后才是把业务逻辑转换成代码

    那么当业务逻辑并没有完全确定的时候,是不能去写代码的,因为这样就算写出来了你想的业务逻辑,业务逻辑没有确定,它一旦崩塌,你就只能重写,如果你去修改维护,只会变成屎山代码

    如果不幸地,代码写完后发现业务逻辑错了,先去想想可不可维护,如果不可维护,把代码删掉重写更节省时间,如果可维护,改几个语句就行了,但是在上手写代码之前业务逻辑一定是完全确定的,不然只会是浪费时间。

    那我们如何去确定业务逻辑呢?如果是个简单的小模拟,直接按照题意做即可。如果是比较大的模拟或者是比较麻烦的模拟的话还是要手推几个例子观察一下再去归纳业务逻辑(比如这道题)

    那么接下来就是如何把业务逻辑转化为代码了:业务逻辑就是概括需要维护的数据,然后用代码把它实现。

    具体怎么实现?代码无非就是 循环,if的嵌套

    如何确定一个循环?截止条件+步长

    在循环里面去维护数据,用if体现业务中的"逻辑"

  • 相关阅读:
    AtCoder Regular Contest 146 C Even XOR题解
    归并排序的简单理解
    自古以来,代理程序都是兵家折戟之地
    UE4c++ ConvertActorsToStaticMesh & ConvertProceduralMeshToStaticMesh
    鱼哥赠书活动第③期:《CTF那些事儿》《构建新型网络形态下的网络空间安全体系》《智能汽车网络安全权威指南》上下册
    【taichi】关于SPH_Taichi的探索与尝试
    数据分析师入门: 数据分析可视化入门知识点
    什么是智慧校园?
    [Spring笔记] Spring-35-AOP通知获取数据
    蓝桥杯——123
  • 原文地址:https://blog.csdn.net/weixin_62528401/article/details/126838627