编辑距离算法:C++ 实现及开发易错点解析
```cpp #include <iostream> #include <string> #include <vector> using namespace std; // 计算两个字符串的编辑距离 int minDistance(string s, string t) { int m = s.size(); int n = t.size(); // 创建一个二维数组dp来存储子问题的解 vector<vector<int>> dp(m + 1, vector<int>(n + 1, 0)); // 初始化第一行和第一列 for (int i = 0; i <= m; i++) { dp[i][0] = i; } for (int j = 0; j <= n; j++) { dp[0][j] = j; } // 填充dp数组 for (int i = 1; i <= m; i++) { for (int j = 1; j <= n; j++) { if (s[i - 1] == t[j - 1]) { // 如果当前字符相等,则不需要额外操作 dp[i][j] = dp[i - 1][j - 1]; } else { // 否则,取插入、删除、替换操作中的最小操作数加1 dp[i][j] = min(min(dp[i - 1][j], dp[i][j - 1]), dp[i - 1][j - 1]) + 1; } } } // 返回最终结果 return dp[m][n]; } int main() { string s, t; // 读取输入的两个字符串 cin >> s >> t; // 计算并输出编辑距离 cout << minDistance(s, t) << endl; return 0; } ``` 我在以往的开发过程中,碰到过以下几点需要格外小心处理的地方: 1. 注意二维数组`dp`的初始化,特别是第一行和第一列的处理,要正确反映边界情况。 2. 循环填充`dp`数组时,数组的索引要与字符串的索引对应,避免出现越界问题。 3. 在比较字符是否相等时,要注意字符串的索引是从0开始,而`dp`数组的索引是从1开始,避免逻辑错误。 ######[AI写代码神器 | 521点数解答 | 2025-08-20 14:58:56]
- 易语言代码优化:自动出售物资子程序整合与优化全解析(DeepSeek | 2181点数解答 | 2025-07-23 10:26:29)214
- Android 课程作业考试管理 APP 开发:全功能实现与上线优化之路(GPT | 84点数解答 | 2024-12-14 13:46:35)277
- Android 学生学习管理 APP:功能完备开发全攻略(字节豆包 | 30点数解答 | 2024-12-14 13:47:04)237
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)345
- Golang开发:解析JSON数据时数值默认类型及示例解析(百度文心 | 393点数解答 | 2023-11-09 18:13:06)278
- SQL Working Areas Sizing: Manual vs. Automatic Policy - A Comprehensive Analysis(阿里通义 | 530点数解答 | 2024-05-13 10:55:58)308
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)313
- Matlab 实现遗传算法求解图最短路径:参数设置与关键操作解析(字节豆包 | 128点数解答 | 2024-11-25 02:48:03)186
- MATLAB代码:修正遗传算法初始化种群代码,解决潜在错误(字节豆包 | 360点数解答 | 2024-11-25 02:48:49)196
- C++代码实现计算骑行总时间及详细解析(字节豆包 | 460点数解答 | 2026-03-03 19:51:23)19
- HTML 代码里藏着的“一起睡觉的幸福”:超链接、图像与 div 的奇妙组合 (阿里通义 | 182点数解答 | 2023-10-26 09:46:09)348
- CSS技巧:鼠标移入a标签自动隐藏指定div(阿里通义 | 181点数解答 | 2023-10-26 09:52:31)396