C++实现最短编辑距离计算:将一个单词转换为另一个的最少操作数揭秘
```cpp #include <iostream> #include <cstdlib> #include <string> #include <vector> using namespace std; int minDistance(string word1, string word2) { int m = word1.length(); int n = word2.length(); 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 (word1[i - 1] == word2[j - 1]) { dp[i][j] = dp[i - 1][j - 1]; } else { 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]; } ``` ######[AI问答 | 311点数解答 | 2025-11-12 14:55:49]
- 易语言代码优化:自动出售物资子程序整合与优化全解析(DeepSeek | 2181点数解答 | 2025-07-23 10:26:29)263
- Android 课程作业考试管理 APP 开发:全功能实现与上线优化之路(GPT | 84点数解答 | 2024-12-14 13:46:35)296
- Android 学生学习管理 APP:功能完备开发全攻略(字节豆包 | 30点数解答 | 2024-12-14 13:47:04)258
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)469
- C语言:实现输入实数和运算符计算表达式值,处理除数为0情况(字节豆包 | 209点数解答 | 2024-10-30 16:14:46)164
- Python 与 C 语言:一行字符串中单词个数统计的实现与解析(字节豆包 | 658点数解答 | 2025-12-07 17:39:44)56
- Python 实现输入字符串统计单词个数,轻松解决连续空格难题!(DeepSeek | 141点数解答 | 2025-12-14 20:12:06)71
- 给定一个包含 个顶点和 条边的无向连通图。如果除了最多一个顶点外,其余所有顶点的度数均为 或 (即不超过一个顶点的度数大于 ),则称其为胡须图。顶点的度数表示和该顶点相连的边的数量。 每条边要么是黑色,要么是白色。所有边初始均为黑色。 现给定一张胡须图的描述,你需要处理下列类型的若干操作: 将编号为 的边涂成黑色。编号 的边指输入顺序的第 条边。保证进行该操作时第 条边是白色。 将编号为 的边涂成白色。保证进行该操作时第 条边是黑色。 查询只经过黑色边,顶点 和 间的最短路径长度,或判断是否不存在这样的路径(路径长度为经过的边数)。 顶点从 到 编号,边从 到 编号。 输入格式 输入的第一行包含一个整数 ( )——图的顶点数。接下来 行,每行两个整数 ( ),表示一条边。保证图连通、是胡须图、无自环、无重边。 之后一行为整数 ( )——操作数。接下来 行,每行为一次操作。每次操作格式如下: 若为操作类型 ,则该行为 1 i,表示将编号为 的边涂为黑色。 若为操作类型 ,则该行为 2 i,表(讯飞星火 | 0点数解答 | 2026-05-30 13:01:05)25
- C++ 利用栈求解唯一路径迷宫:从起点 (1,1) 到终点 (m - 2,n - 2)(阿里通义 | 732点数解答 | 2024-11-03 02:34:53)548
- C++ 实现:从大整数中删数求最小密码的巧妙算法(DeepSeek | 473点数解答 | 2025-06-20 16:08:21)227
- Matlab 实现遗传算法求解图最短路径:参数设置与关键操作解析(字节豆包 | 128点数解答 | 2024-11-25 02:48:03)227
- MATLAB代码:修正遗传算法初始化种群代码,解决潜在错误(字节豆包 | 360点数解答 | 2024-11-25 02:48:49)216