相似度为K的字符串

题目描述

如果可以通过将 A 中的两个小写字母精确地交换位置 K 次得到与 B 相等的字符串,我们称字符串 A 和 B 的相似度为 K(K 为非负整数)。

给定两个字母异位词 A 和 B ,返回 A 和 B 的相似度 K 的最小值。

示例1

输入:A = "ab", B = "ba"
输出:1

示例2

输入:A = "abc", B = "bca"
输出:2

示例3

输入:A = "abac", B = "baca"
输出:2

示例4

输入:A = "aabc", B = "abca"
输出:2

思路

广搜:我们尽量先把前面的字符串换成相等的,每次从后面去找字符换过来

也可以用深搜+贪心的思路

实现

int kSimilarity(string A, string B) {
        queue<string>que;
        que.push(A);
        int level = 0,cur=0;
        unordered_map<string, bool>visited;
        while (!que.empty())
        {
            int num = que.size();
            while (num--)
            {
                auto top = que.front();
                if (top == B)
                    return level;
                que.pop();
                int i, j;
                for (i = cur; i < top.size() && top[i] == B[i]; i++);
                j = i + 1;
                for (; j < top.size(); j++)
                    if (top[j] == B[i])
                    {
                        swap(top[i], top[j]);
                        if (!visited[top])
                        {
                            que.push(top);
                            visited[top] = true;
                        }
                        swap(top[i], top[j]);
                    }
            }
            level++;
            cur++;
        }
        return 0;
	}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值