今天做题十分不在状态,这道题本来相当简单,但是我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;
}