今天做题十分不在状态,这道题本来相当简单,但是我TM又看错题了。
我在字符判断的时候,把l看成了一,导致我以为是标准库用错了,又换了纯C的写一遍,结果发现还是有问题,最后看了别人的代码才发现,原来是题目没看清,心不在焉,效率减半。
#include<iostream>
#include<vector>
#include<string>
using namespace std;
struct node{
string name,passw;
int flag = 1;
}tmp;
vector<node> v;
int main(){
int n,cnt=0;
scanf("%d",&n);
for(int i=0;i<n;i++){
cin>>tmp.name>>tmp.passw;
int flag=0;
for(int j=0;j<tmp.passw.size();j++){
if(tmp.passw[j]=='1') {
flag=1;
tmp.passw[j]='@';
}
if(tmp.passw[j]=='0') {
flag=1;
tmp.passw[j]='%';
}
if(tmp.passw[j]=='l') {
flag=1;
tmp.passw[j]='L';
}
if(tmp.passw[j]=='O') {
flag=1;
tmp.passw[j]='o';
}
}
if(flag==1) {
cnt++;
tmp.flag=1;
}else tmp.flag=0;
v.push_back(tmp);
}
if(cnt==0) {
if(n==1) printf("There is 1 account and no account is modified");
else printf("There are %d accounts and no account is modified\n",n);
}
else {
printf("%d\n",cnt);
for(int i=0;i<n;i++){
if(v[i].flag ==1){
cout<<v[i].name <<" "<<v[i].passw<<endl;
}
}
}
return 0;
}