4612: 【GESP2403四级】相似字符串

内存限制:128 MB 时间限制:1.000 S
评测方式:文本比较 命题人:
提交:1 解决:1

题目描述

对于两个字符串A 和B ,如果A 可以通过删除一个字符,或插入一个字符,或修改一个字符变成B ,那么我们说A和B 是相似的。
比如 apple 可以通过插入一个字符变成 applee ,可以通过删除一个字符变成 appe ,也可以通过修改一个字符变成 bpple ,因此 appleappleeappebpple 都是相似的。但 applee 并不能通过任意一个操作变成bpple ,因此它们并不相似。
特别地,完全相同的两个字符串也是相似的。
给定$T$ 组A、B ,请你分别判断他们是否相似。

输入

第一行一个正整数$T$ 。
接下来$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;
 }