【模板】最长递增公共子序列

二维:

#include 
#include 
#include 
using namespace std;

int n,m,a[505],b[505],dp[505][505];

int LICS()
{
    int MAX,i,j;
    memset(dp,0,sizeof(dp));
    for(i = 1; i<=n; i++)
    {
        MAX = 0;
        for(j = 1; j<=m; j++)
        {
            dp[i][j] = dp[i-1][j];
            if(a[i]>b[j] && MAX


优化成一维

#include 
#include 
#include 
using namespace std;

int a[505],b[505],dp[505],n,m;

int LICS()
{
    int i,j,MAX;
    memset(dp,0,sizeof(dp));
    for(i = 1; i<=n; i++)
    {
        MAX = 0;
        for(j = 1; j<=m; j++)
        {
            if(a[i]>b[j] && MAX


 

你可能感兴趣的:(【模板啊模板】)