标签:read lis ios i++ turn sig oid using ++
一道经典\(DP\)
LCS
\[ f[i][j]=f[i-1][j-1]+1\;(i,j>0,a[i]=b[j])\]
\[ f[i][j]=max(f[i][j-1],f[i-1][j])\;(i,j>0,a[i]\not=b[j])\]
其中,f[i][j]
为a
序列前i
个元素与b
序列前j
个元素的\(LCS\)长度
LIS
\[f[i]=max~f[j]+1~(j
f[i]
为以第i
个元素结尾的\(LIS\)长度。
LCIS
我们想办法糅合这两种动态规划的思想,设f[i][j]
代表的是a
序列前i
个元素与b
序列前j
个元素的\(LCIS\)长度(最长公共上升子序列),t
为最长\(LCIS\)的结尾元素位置,我们可以推出状态转移方程
\[f[i][j]=f[i-1][j]~(a[i]\not=b[j])\]
\[f[i][j]=max(f[i-1][j],f[i-1][t]+1)~(a[i]=b[j])\]
最后,再转移时储存位置,输出
Code One
二维
#include
#include
#include
#include
#include
#include
#include
#define ll long long
#define maxn 550
#define inf 2147483647
#define mod 10003
#define eps 1e-6
#define pi acos(-1.0)
#define de(x) ((x)*(x))
using namespace std;
inline int read(){
int x=0,f=1; char ch=getchar();
while(!isdigit(ch)) {if(ch=='-')f=-1;ch=getchar();}
while(isdigit(ch)) {x=x*10+ch-48;ch=getchar();}
return x*f;
}
int n,a[maxn],b[maxn],f[maxn][maxn],g[maxn][maxn];
inline void put(int x){
if(!x) return;
put(g[n][x]);
printf("%d ",b[x]);
}
signed main(){
n=read();
for(int i=1;if[i][j]){
f[i][j]=f[i-1][t]+1;
g[i][j]=t;
}
if(b[j]f[i-1][t]) t=j;
//检查t是否为最长LCIS的结尾元素位置
}
for(int i=1;if[n][p]) p=i;
printf("%d\n",f[n][p]);
put(p);
return 0;
}
优化
分析状态转移方程可知f[i][j]
都是由f[i-1][j]
得来的,因此可以优化空间,设f[i]
代表的是a
序列前i
个元素与b
序列的LCIS
长度,t
为最长LCIS
的结尾元素位置,新的状态转移方程为
\[f[i]=f[t]+1~(a[i]=b[j])\]
Code Two
#include
#include
#include
#include
#include
#include
#include
#define ll long long
#define maxn 550
#define inf 2147483647
#define mod 10003
#define eps 1e-6
#define pi acos(-1.0)
#define de(x) ((x)*(x))
using namespace std;
inline int read(){
int x=0,f=1; char ch=getchar();
while(!isdigit(ch)) {if(ch=='-')f=-1;ch=getchar();}
while(isdigit(ch)) {x=x*10+ch-48;ch=getchar();}
return x*f;
}
int n,a[maxn],b[maxn],f[maxn],g[maxn];
inline void put(int x){
if(!x) return;
put(g[x]);
printf("%d ",b[x]);
}
signed main(){
n=read();
for(int i=1;if[p]) p=i;
printf("%d\n",f[p]);
put(p);
return 0;
}
效果显著
\(P.S\)可以写写Acwing 272
CF10D LCIS&&Acwing 272
标签:read lis ios i++ turn sig oid using ++
原文地址:https://www.cnblogs.com/cbyyc/p/11455793.html