Levenshtein距离用动态规划二维表实现,dpi表示s1前i字符到s2前j字符的最小编辑距离,初始化边界后按相等/不等转移,时间O(mn),空间可优化至O(min(m,n))。

c++怎么实现字符串的模糊搜索_c++ 编辑距离算法Levenstein实现【案例】

Levenshtein 距离函数怎么写(C++ 基础实现)

直接用动态规划填二维表是最清晰、最易调试的写法。核心是定义 dp[i][j] 表示 s1.substr(0, i)s2.substr(0, j) 的最小编辑距离,状态转移只依赖左、上、左上三个格子。

注意边界初始化:空字符串到长度为 j 的字符串需要 j 次插入;同理,长度为 i 到空字符串需 i 次删除。

int levenshtein(const std::string& s1, const std::string& s2) {
    int m = s1.size(), n = s2.size();
    std::vector> dp(m + 1, std::vector(n + 1));
for (int i = 0; i <= m; ++i) dp[i][0] = i;
for (int j = 0; j <= n; ++j) dp[0][j] = j;

for (int i = 1; i <= m; ++i) {
    for (int j = 1; j <= n; ++j) {
        if (s1[i-1] == s2[j-1]) {
            dp[i][j] = dp[i-1][j-1];
        } else {
            dp[i][j] = 1 + std::min({
                dp[i-1][j],    // 删除
                dp[i][j-1],    // 插入
                dp[i-1][j-1]   // 替换
            });
        }
    }
}
return dp[m][n];

}

如何用 Levenshtein 实现模糊搜索(带阈值匹配)

编辑距离本身不是“搜索”,而是衡量相似度的工具。模糊搜索的关键在于:对候选字符串批量调用 levenshtein(),再按距离排序或过滤。

为什么不用 std::string::find 或正则做模糊匹配

std::string::find 只支持精确子串匹配,不处理错字、漏字、顺序颠倒;std::regex 虽可写通配模式(如 "a.*b.*c"),但无法量化“多像”,也不能自然表达“替换一个字符”这种语义。

例如搜索 "recieve"(拼错)想命中 "receive"

性能和内存要注意什么(尤其嵌入式或高频调用场景)

原版二维 DP 时间 O(m×n),空间 O(m×n)。实际工程中容易成为瓶颈:

真正卡住的往往不是算法本身,而是反复构造 std::vector 和频繁内存分配。如果搜索逻辑固定且候选集不变,把距离矩阵预计算好、查表会更快。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。