leetcode热题 - 4

距离字典两次编辑以内的单词

问题描述

给你两个字符串数组 queries 和 dictionary 。数组中所有单词都只包含小写英文字母,且长度都相同。

一次 编辑 中,你可以从 queries 中选择一个单词,将任意一个字母修改成任何其他字母。从 queries 中找到所有满足以下条件的字符串:不超过 两次编辑内,字符串与 dictionary 中某个字符串相同。

请你返回 queries 中的单词列表,这些单词距离 dictionary 中的单词 编辑次数 不超过 两次 。单词返回的顺序需要与 queries 中原本顺序相同。

(真题链接:距离字典两字编辑以内的单词

解题思路

这一题的解题思路非常清晰,给你两个字符串数组queriesdictionary,由于所有字符串的长度都相同,因此我们只需要对queries数组中的每一个字符串进行遍历,求出其与dictionary字符串数组中每一个单词的汉明距离,最后将汉明距离小于2的字符串返回即可得到答案。

这里科普一下汉明距离是什么:

汉明距离表示两个等长字符串之间对应位置的不同字符的个数。它衡量的是两个字符串需要改变多少个位置才能变得完全相同。

定义:对于两个长度相同的字符串 A 和 B,它们的汉明距离就是在相同位置上,A 和 B 字符不同的位置的数量。

符号:通常用 d(A, B) 表示。

例子:

1011101 与 1001001:比较每一位,第3位(1 vs 0)、第5位(1 vs 0)不同,所以汉明距离是 2。

karolin 与 kathrin:比较每一位,第3位(r vs t)、第4位(o vs h)、第5位(l vs r)不同,所以汉明距离是 3。

12345 与 54321:全部5位都不同,汉明距离是 5。

注意:汉明距离要求两个字符串长度必须相等。如果长度不同,通常需要先对齐或使用其他距离度量(如编辑距离)。

代码实现

cpp 复制代码
class Solution {
public:
    vector<string> twoEditWords(vector<string>& queries, vector<string>& dictionary) {
        vector<string> ans;
        for (string query : queries) {
            for (string s : dictionary) {
                int dis = 0;
                for (int i = 0; i < query.size(); i++) {
                    if (query[i] != s[i]) {
                        ++dis;
                    }
                }
                if (dis <= 2) {
                    ans.push_back(query);
                    break;
                }
            }
        }
        return ans;
    }
};

复杂度分析

复杂度 量级
时间复杂度 O(n × m)
空间复杂度 O(n)

总结

这道题要求从 queries 中找出所有与 dictionary 中任意单词汉明距离不超过 2 (即最多修改两个字母就能变成字典中的某个词)的单词,并按原顺序返回。核心解题思路是:因为所有单词等长,所以直接对每个 query 遍历 dictionary 中的所有单词,逐位比较计算汉明距离(即对应位置字符不同的个数),一旦找到距离 ≤ 2 的单词,就将该 query 加入答案并跳过剩余字典(break),最终返回答案列表。该方法本质是三重循环暴力枚举,时间复杂度 O(n × m × L),但由于单词长度和数组规模通常较小,足以通过题目测试。

相关推荐
KaMeidebaby11 小时前
卡梅德生物技术快报|单克隆抗体人源化 PEG 修饰质控方法体系构建与验证
服务器·前端·数据库·人工智能·算法·百度·新浪微博
不知名的老吴11 小时前
二叉树的遍历算法之先序遍历
算法
liu****11 小时前
第16届国赛蓝桥杯大赛C/C++大学B组
c语言·数据结构·c++·算法·蓝桥杯
SimpleLearingAI12 小时前
大模型推理框架总结解析
算法
Σίσυφος190012 小时前
正则化数据并校准数据
人工智能·算法·机器学习
HZ·湘怡12 小时前
基于动态数组的栈(顺序栈)01
数据结构·算法
Chen_harmony12 小时前
十八、C语言内存函数
c语言·算法
__Coffee__12 小时前
封装矩阵结构体
线性代数·算法·矩阵
变量未定义~12 小时前
字符串哈希匹配字符串
数据结构·算法·哈希算法
周末也要写八哥12 小时前
浅谈二叉树的深度优先搜索(DFS)算法
算法·深度优先