4612: 【GESP2403四级】相似字符串
内存限制:128 MB
时间限制:1.000 S
评测方式:文本比较
命题人:
提交:1
解决:1
题目描述
对于两个字符串A 和B ,如果A 可以通过删除一个字符,或插入一个字符,或修改一个字符变成B ,那么我们说A和B 是相似的。
比如
特别地,完全相同的两个字符串也是相似的。
给定$T$ 组A、B ,请你分别判断他们是否相似。
比如
apple 可以通过插入一个字符变成 applee ,可以通过删除一个字符变成 appe ,也可以通过修改一个字符变成 bpple ,因此 apple 和 applee 、 appe 、 bpple 都是相似的。但 applee 并不能通过任意一个操作变成bpple ,因此它们并不相似。特别地,完全相同的两个字符串也是相似的。
给定$T$ 组A、B ,请你分别判断他们是否相似。
输入
第一行一个正整数$T$ 。
接下来$T$ 行,每行两个用空格隔开的字符串A 和B 。
保证$T\le 100$ ,A、B 的长度不超过$50$ 。保证A 和B 只包含小写字母。
接下来$T$ 行,每行两个用空格隔开的字符串A 和B 。
保证$T\le 100$ ,A、B 的长度不超过$50$ 。保证A 和B 只包含小写字母。
输出
输出 行,对于每组A、B ,如果它们相似,则输出
similar ,否则输出 not similar 。
样例输入 复制
5
apple applee
apple appe
apple bpple
applee bpple
apple apple
样例输出 复制
similar
similar
similar
not similar
similar
提示
#include <iostream>
#include <string>
using namespace std;
bool isSimilar(string A, string B) {
int m = A.size(), n = B.size();
if (abs(m - n) > 1) return false;
if (m == n) {
int diff = 0;
for (int i = 0; i < m; ++i) {
if (A[i] != B[i]) {
if (++diff > 1) return false;
}
}
return diff <= 1;
} else {
string& shorter = (m < n) ? A : B;
string& longer = (m < n) ? B : A;
int i = 0, j = 0;
int diff = 0;
while (i < shorter.size() && j < longer.size()) {
if (shorter[i] != longer[j]) {
if (++diff > 1) return false;
++j;
} else {
++i;
++j;
}
}
return true;
}
}
int main() {
int T;
cin >> T;
while (T--) {
string A, B;
cin >> A >> B;
if (isSimilar(A, B)) {
cout << "similar" << endl;
} else {
cout << "not similar" << endl;
}
}
return 0;
}