Mai intai trebuie sa te autentifici.
Cod sursa(job #1799162)
Utilizator | Data | 5 noiembrie 2016 20:58:21 | |
---|---|---|---|
Problema | Cel mai lung subsir comun | Scor | 0 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 1.35 kb |
#include <fstream>
#include <vector>
#include <algorithm>
using namespace std;
vector<int> findSubsequence(
const vector<int>& a,
const vector<int>& b,
const vector<vector<int>>& dp) {
vector<int> sequence;
for (int i = int(a.size()), j = int(b.size()); i > 0 && j > 0; ) {
if (a[i] == b[j] && dp[i][j] == 1 + dp[i - 1][j - 1]) {
sequence.push_back(a[i]);
--i;
--j;
} else if (dp[i][j] == dp[i - 1][j] + 1) {
--i;
} else if (dp[i][j] == dp[i][j - 1]) {
--j;
}
}
reverse(sequence.begin(), sequence.end());
return sequence;
}
vector<int> longestCommonSubsequence(
const vector<int>& a,
const vector<int>& b) {
const int n = int(a.size());
const int m = int(b.size());
auto dp = vector<vector<int>>(n + 1, vector<int>(m + 1, 0));
for (int i = 1; i <= n; ++i) {
for (int j = 1; j <= m; ++j) {
dp[i][j] = max(dp[i - 1][j], dp[i][j - 1]);
if (a[i] == b[j]) {
dp[i][j] = max(dp[i][j], 1 + dp[i - 1][j - 1]);
}
}
}
return findSubsequence(a, b, dp);
}
int main() {
ifstream in("cmlsc.in");
ofstream out("cmlsc.out");
int n[2];
in >> n[0] >> n[1];
vector<int> sequences[2];
for (int i = 0; i < 2; ++i) {
sequences[i] = vector<int>(n[i]);
for (int j = 0; j < n[i]; ++j) {
in >> sequences[i][j];
}
}
in.close();
out.close();
return 0;
}