题意:
来更一道水的不能再水的模拟....
题意:
有一个从字符翻译到数字的映射规则:
如果字符的数字只有个位数,就直接翻译
如果字符的数字是两位数,就翻译后在数字末尾加0
现在给你一串数字,让你还原这个字符串
思路:
模拟:
有两个做法:一个是倒序遍历,遇到0就把0前两个数字变成字符就好了
另一个是分类讨论,4个4个遍历,当且仅当第3个数是0且第4个数不是0且没越界时映射两位数,否则就映射一位数
Code:
#include <bits/stdc++.h>
using namespace std;
int n;
string s,ans;
void solve(){
ans.clear();
cin>>n>>s;
s='?'+s;
for(int i=1;i<=n;i++){
if(s[i+2]=='0'&&i+2<=n&&(s[i+3]!='0'||i+3>n)){
int tmp=(s[i]-'0')*10+s[i+1]-'0';
ans+=tmp+'a'-1;
i+=2;
}else{
int tmp=s[i]-'0';
ans+=tmp+'a'-1;
}
}
cout<<ans<<endl;
}
int main(){
ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
int T;
cin>>T;
while(T--) solve();
return 0;
}
总结:我们是怎么模拟的?
首先,我们要确定我们的业务逻辑,然后才是把业务逻辑转换成代码
那么当业务逻辑并没有完全确定的时候,是不能去写代码的,因为这样就算写出来了你想的业务逻辑,业务逻辑没有确定,它一旦崩塌,你就只能重写,如果你去修改维护,只会变成屎山代码
如果不幸地,代码写完后发现业务逻辑错了,先去想想可不可维护,如果不可维护,把代码删掉重写更节省时间,如果可维护,改几个语句就行了,但是在上手写代码之前业务逻辑一定是完全确定的,不然只会是浪费时间。
那我们如何去确定业务逻辑呢?如果是个简单的小模拟,直接按照题意做即可。如果是比较大的模拟或者是比较麻烦的模拟的话还是要手推几个例子观察一下再去归纳业务逻辑(比如这道题)
那么接下来就是如何把业务逻辑转化为代码了:业务逻辑就是概括需要维护的数据,然后用代码把它实现。
具体怎么实现?代码无非就是 循环,if的嵌套
如何确定一个循环?截止条件+步长
在循环里面去维护数据,用if体现业务中的"逻辑"