C で最長共通部分列アルゴリズムを使用する方法
最長共通部分列 (LCS) は、2 つの文字列内で最長の同一部分列を見つける共通文字列マッチング問題です。 C では、動的プログラミング (Dynamic Programming) を使用して LCS 問題を解決できます。
以下は、最長共通部分列アルゴリズムの使用方法を示す C コードの例です:
#include <iostream> #include <vector> #include <string> using namespace std; string longestCommonSubsequence(string text1, string text2) { int m = text1.size(); int n = text2.size(); // 创建一个二维数组来存储中间结果 vector<vector<int>> dp(m+1, vector<int>(n+1, 0)); // 进行动态规划,填充数组 for (int i = 1; i <= m; i++) { for (int j = 1; j <= n; j++) { // 如果当前字符相等,则在之前的基础上加1 if (text1[i-1] == text2[j-1]) { dp[i][j] = dp[i-1][j-1] + 1; } else { // 如果当前字符不相等,则取左边或上边的最大值 dp[i][j] = max(dp[i-1][j], dp[i][j-1]); } } } // 根据dp数组构建最长公共子序列 int i = m; int j = n; string lcs = ""; while (i > 0 && j > 0) { if (text1[i-1] == text2[j-1]) { // 如果当前字符相等,则将字符加入最长公共子序列中 lcs = text1[i-1] + lcs; i--; j--; } else { // 如果当前字符不相等,则根据dp数组移动指针 if (dp[i-1][j] >= dp[i][j-1]) { i--; } else { j--; } } } return lcs; } int main() { string text1 = "ABCD"; string text2 = "ACDF"; string lcs = longestCommonSubsequence(text1, text2); cout << "最长公共子序列为:" << lcs << endl; return 0; }
上記のコードでは、最初に動的プログラミングを使用して 2 次元配列を構築しますdp
、dp[i][j]
は、text1
の最初の i
文字と text2 の最初の
を表します。 j
文字で構成される最長の共通部分シーケンスの長さ。次に、dp
配列を使用して、動的プログラミングの結果に基づいて最長の共通部分列を構築します。最後に、最長の共通部分列を出力するだけです。
上記は、C で最長共通部分列アルゴリズムを使用する例です。動的プログラミングのアイデアを通じて、LCS 問題を効率的に解決し、2 つの文字列内の最長の共通部分列を見つけることができます。
以上がC++ で最長共通部分列アルゴリズムを使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。