http://poj.org/problem?id=1458
经典LIS最长公共子序列问题
我设计了一个d函数来处理数组越界的情况
#include <iostream>
#include <string>
#include <cstring>
#include <cstdio>
using namespace std;
string a, b;
const int MAXL = 1000;
int dp[MAXL][MAXL];
int d(int i, int j)
{
if (i < 0 || j < 0) return 0;
return dp[i][j];
}
void solve()
{
memset(dp, 0, sizeof(dp));
for (int i = 0; i < a.size(); i++) {
for (int j = 0; j < b.size(); j++) {
if (a[i] == b[j]) {
dp[i][j] = d(i - 1, j - 1) + 1;
} else
{
dp[i][j] = max(d(i - 1, j), d(i, j - 1));
}
}
}
int ans = dp[a.size() - 1][b.size() - 1];
printf("%d\n", ans);
}
int main()
{
//freopen("in.txt", "r", stdin);
while (cin >> a >> b) {
solve();
}
}