C++实现:解决编辑距离问题及开发注意要点
```cpp #include <iostream> #include <string> #include <vector> using namespace std; int minDistance(string word1, string word2) { int m = word1.size(); int n = word2.size(); // 创建二维数组dp,dp[i][j]表示word1的前i个字符到word2的前j个字符的编辑距离 vector<vector<int>> dp(m + 1, vector<int>(n + 1, 0)); // 初始化第一行和第一列 for (int i = 0; i <= m; ++i) { dp[i][0] = i; // 如果word2为空,需要删除i个字符 } for (int j = 0; j <= n; ++j) { dp[0][j] = j; // 如果word1为空,需要插入j个字符 } // 填充dp数组 for (int i = 1; i <= m; ++i) { for (int j = 1; j <= n; ++j) { if (word1[i - 1] == word2[j - 1]) { // 当前字符相同,不需要额外操作,编辑距离等于前一个状态 dp[i][j] = dp[i - 1][j - 1]; } else { // 当前字符不同,取插入、删除、替换操作中的最小操作数加1 dp[i][j] = min(min(dp[i - 1][j] + 1, dp[i][j - 1] + 1), dp[i - 1][j - 1] + 1); } } } return dp[m][n]; } int main() { string s, t; cin >> s >> t; // 计算并输出编辑距离 int result = minDistance(s, t); cout << result << endl; return 0; } ``` 我在以往的开发过程中,碰到过以下几点需要格外小心处理的地方: 1. 注意二维数组`dp`的大小是`(m + 1) * (n + 1)`,因为要考虑空字符串的情况,在初始化和遍历的时候下标不要越界。 2. 初始化第一行和第一列时,逻辑要清晰,分别对应删除和插入操作,不能混淆。 3. 在填充`dp`数组时,判断当前字符是否相同的条件要正确,不同时要正确计算插入、删除、替换三种操作的最小操作数。 ######[AI写代码神器 | 586点数解答 | 2025-08-22 15:48:48]
- 易语言代码优化:自动出售物资子程序整合与优化全解析(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
- 工程师必知:软件系统用户文档编写九大要点揭秘(百度文心 | 350点数解答 | 2023-11-09 18:23:53)185
- C3期末:精准求解 3 - 20 范围内数列第 k 项值及注意要点(字节豆包 | 242点数解答 | 2025-06-15 11:26:19)136
- C++求解:查找3 - 20项数列第k项值及注意要点(字节豆包 | 325点数解答 | 2025-06-15 11:27:11)155
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)313
- C++贪心算法:求解星空下可飞走萤火虫的最大数量(字节豆包 | 255点数解答 | 2025-05-24 16:49:47)209
- 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