C++求解编辑距离:普通写法要点与易错提示
```cpp #include <iostream> #include <cstring> using namespace std; const int MAXN = 2005; // 定义一个二维数组来存储子问题的解 int dp[MAXN][MAXN]; int min(int a, int b, int c) { // 找出三个数中的最小值 if (a <= b && a <= c) return a; if (b <= a && b <= c) return b; return c; } int main() { char s[MAXN], t[MAXN]; // 读取两个输入的字符串 cin >> s >> t; int lenS = strlen(s); int lenT = strlen(t); // 初始化边界条件 for (int i = 0; i <= lenS; i++) { dp[i][0] = i; } for (int j = 0; j <= lenT; j++) { dp[0][j] = j; } // 动态规划填充dp数组 for (int i = 1; i <= lenS; i++) { for (int j = 1; j <= lenT; j++) { if (s[i - 1] == t[j - 1]) { dp[i][j] = dp[i - 1][j - 1]; } else { // 取插入、删除、替换三种操作的最小值加1 dp[i][j] = min(dp[i - 1][j] + 1, dp[i][j - 1] + 1, dp[i - 1][j - 1] + 1); } } } // 输出结果 cout << dp[lenS][lenT] << endl; return 0; } ``` 我在以往的开发过程中,碰到过以下几点需要格外小心处理的地方: 1. 注意字符串数组的下标从0开始,而`dp`数组的下标从1开始处理子问题,避免出现数组越界错误。 2. 边界条件的初始化很重要,要确保`dp[i][0]`和`dp[0][j]`正确初始化,否则会影响最终结果。 3. 在比较字符是否相等时,要注意字符串的下标和`dp`数组下标的对应关系,避免出现逻辑错误。 ######[AI写代码神器 | 547点数解答 | 2025-08-22 15:49:32]
- 易语言代码优化:自动出售物资子程序整合与优化全解析(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
- C++ 实现快递公司运费计算:根据重量与类型精准算出费用(字节豆包 | 480点数解答 | 2025-12-21 22:04:58)84
- C++ 实现根据重量与快递类型计算某快递公司运费(字节豆包 | 472点数解答 | 2025-12-27 20:39:33)37
- C++ 实现快递公司运费计算:根据重量与类型精准算费(字节豆包 | 385点数解答 | 2026-02-03 14:00:23)51
- C++ 实现快递公司运费计算程序(字节豆包 | 479点数解答 | 2026-02-13 22:32:35)16
- 工程师必知:软件系统用户文档编写九大要点揭秘(百度文心 | 350点数解答 | 2023-11-09 18:23:53)185
- 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