题目描述
小天使的b站帐号被大家发现啦。于是小天使决定改名,将他原有ID中的两个不同位置的字母进行交换。(小天使有可能将两个不同位置的相同字母进行交换,虽然这样做他的ID并没有发生变化)
Lsf知道小天使原来的ID,他想知道某个ID是否可能是小天使的新ID。
输入
第一行为数据组数T(T≤100)。
每组数据的第一行是字符串s1,(2≤length(s1)≤1000),为小天使的原始ID。
第二行是字符串s2,(length(s2)=length(s1)),为Lsf猜测的ID。
s1,s2均只含小写字母。
输出
对每组数据输出一行,如果这个ID可能是小天使的新ID,输出YES,否则输出NO。
样例输入
3
ch
hc
aa
aa
abc
abb
样例输出
YES
YES
NO
心塞到不能行,比赛的时候没有考虑到如果两个字符串相同,但是没有重复的字符,例如ab ab应该是NO
#include<iostream> #include<cstdio> #include<cstring> using namespace std; int main(){ char s1[1005],s2[1005]; char c1[1005],c2[1005]; int t; int l,i,k,f; scanf("%d",&t); while(t--){ scanf("%s%s",s1,s2); l=strlen(s1); k=0; f=0; for(i=0;i<l;i++){ if(s1[i]==s1[i+1]) f=1;//看有没有重复字符 if(s1[i]!=s2[i]){ c1[k]=s1[i]; c2[k]=s2[i]; k++;//记录连个字符串中有多少个字符不同 } } if(k==0 && f)//k==0 字符串莉要有重复字符才行 printf("YES\n"); else if(k==2){ if(c1[0]==c2[1] && c1[1]==c2[0]) printf("YES\n"); else printf("NO\n"); } else printf("NO\n"); } }