您的位置:首页 >C++模糊搜索实现_编辑距离Levenstein算法案例
发布于2026-04-09 阅读(0)
扫一扫,手机访问
Levenshtein距离用动态规划二维表实现,dpi表示s1前i字符到s2前j字符的最小编辑距离,初始化边界后按相等/不等转移,时间O(mn),空间可优化至O(min(m,n))。

直接用动态规划填二维表是最清晰、最易调试的写法。核心是定义 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(),再按距离排序或过滤。
std::min(s1.size(), s2.size()) / 3 或固定小整数(如 1~3),避免长串误匹配abs((int)s1.size() - (int)s2.size()) > threshold 直接跳过std::tolower 转换,否则 "Apple" 和 "apple" 距离为 1(首字母替换),而非 0std::string::find 只支持精确子串匹配,不处理错字、漏字、顺序颠倒;std::regex 虽可写通配模式(如 "a.*b.*c"),但无法量化“多像”,也不能自然表达“替换一个字符”这种语义。
例如搜索 "recieve"(拼错)想命中 "receive":
find("receive") 失败(不相等)R"([rR][eE][cC][eE][iI][vV][eE])" 仍要求完全匹配,没解决错位原版二维 DP 时间 O(m×n),空间 O(m×n)。实际工程中容易成为瓶颈:
std::vector 轮换std::string 构造:传参用 const std::string&,内部别做 s1 + "x" 这类拼接simd-string)真正卡住的往往不是算法本身,而是反复构造 std::vector 和频繁内存分配。如果搜索逻辑固定且候选集不变,把距离矩阵预计算好、查表会更快。
上一篇:喜马拉雅历史记录怎么查
下一篇:手机视频转音频方法详解
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9