题目:http://poj.org/problem?id=2127

十分费劲地终于记录好了路径……用一个前驱。

这是 n^2 的LICS方法。其实就是 n ^ 2 log n 把“找之前的d [ j ]的max”用树状数组弄成了 n ^ 2,而这个则在每个 i 遍历 j 的时候顺便更新记录好了要用的那个值,就线性了。

j 是脚标。k 的更新有时间差,保证了“只能用脚标比自己小的”这个条件。

#include<iostream>
#include<cstdio>
#include<cstring>
#define ll long long
using namespace std;
int n,m;
bool use[][];
ll a[],b[],d[],pre[][][];//0是行,1是列;表示第i行与j匹配时
void print(ll cnt,ll k) //用了这个i吗?(和j匹配时)(use[i][j])
{ //上一个是?(行是0,上一行与pre[1]匹配时,以定位)
// printf("(cnt=%lld k=%lld)",cnt,k);
if(!cnt)return;
print(pre[][cnt][k],pre[][cnt][k]);
if(use[cnt][k])printf("%lld ",b[k]);//主要用在cnt==n时判断输出此i否
}
int main()
{
scanf("%d",&n);
for(int i=;i<=n;i++)scanf("%lld",&a[i]);
scanf("%d",&m);
for(int i=;i<=m;i++)scanf("%lld",&b[i]);
for(int i=;i<=n;i++)
{
ll k=;
for(int j=;j<=m;j++) //若没有选此i,行是之前的(就像d的自然copy一样)
{
if(use[i-][j])
{
pre[][i][j]=i-;pre[][i][j]=j;
}
else
{
pre[][i][j]=pre[][i-][j];pre[][i][j]=pre[][i-][j];
}
}
for(int j=;j<=m;j++)
{
if(a[i]>b[j]&&d[j]>d[k])k=j;
else if(a[i]==b[j]&&d[j]<d[k]+)//选此i
{
d[j]=d[k]+;
if(use[i-][k])
{
pre[][i][j]=i-;pre[][i][j]=k;
}
else
{
pre[][i][j]=pre[][i-][k];pre[][i][j]=k;//用的不是上一行的j,而是k
}
use[i][j]=;
}
}
}
ll mx=,k=;
for(int i=;i<=m;i++)
if(d[i]>mx)mx=d[i],k=i;
printf("%lld\n",mx);
print(n,k);
return ;
}

为什么这个比上一个慢?

#include<iostream>
#include<cstdio>
#include<cstring>
#define ll long long
using namespace std;
int n,m;
bool use[][];
ll a[],b[],d[],pre[][][];//0是行,1是列;表示第i行与j匹配时
void print(ll cnt,ll k) //用了这个i吗?(和j匹配时)(use[i][j])
{ //上一个是?(行是0,上一行与pre[1]匹配时,以定位)
// printf("(cnt=%lld k=%lld)",cnt,k);
if(!cnt)return;
print(pre[][cnt][k],pre[][cnt][k]);
// if(use[cnt][k])printf("%lld ",b[k]);//主要用在cnt==n时判断输出此i否
printf("%lld ",b[k]);
}
int main()
{
scanf("%d",&n);
for(int i=;i<=n;i++)scanf("%lld",&a[i]);
scanf("%d",&m);
for(int i=;i<=m;i++)scanf("%lld",&b[i]);
for(int i=;i<=n;i++)
{
ll k=;
for(int j=;j<=m;j++) //若没有选此i,行是之前的(就像d的自然copy一样)
{
if(use[i-][j])
{
pre[][i][j]=i-;pre[][i][j]=j;
}
else
{
pre[][i][j]=pre[][i-][j];pre[][i][j]=pre[][i-][j];
}
}
for(int j=;j<=m;j++)
{
if(a[i]>b[j]&&d[j]>d[k])k=j;
else if(a[i]==b[j]&&d[j]<d[k]+)//选此i
{
d[j]=d[k]+;
if(use[i-][k])
{
pre[][i][j]=i-;pre[][i][j]=k;
}
else
{
pre[][i][j]=pre[][i-][k];pre[][i][j]=k;//用的不是上一行的j,而是k
}
use[i][j]=;
}
}
}
ll mx=,k=;
for(int i=;i<=m;i++)
if(d[i]>mx)mx=d[i],k=i;
printf("%lld\n",mx);
if(use[n][k])print(n,k);
else print(pre[][n][k],k);
return ;
}

另一种记录路径的方法

#include<iostream>
#include<cstdio>
#define ll long long
using namespace std;
const ll INF=;//////防RE,不能大于底下的数组
ll n,m;
ll a[],b[],d[],pre[][];
bool prin[];
void print(ll i,ll j)
{
if(!i)return;
print(i-,pre[i][j]);
if(pre[i-][j]!=pre[i][j]&&!prin[j])printf("%lld ",b[j]),prin[j]=;//以防真实匹配的i的后一个非真实时的输出
// printf("i=%d j=%d\n",i,j); //用d的值判断比较方便,但不想开二维
}
int main()
{
scanf("%lld",&n);
for(ll i=;i<=n;i++)scanf("%lld",&a[i]);
scanf("%lld",&m);
for(ll i=;i<=m;i++)scanf("%lld",&b[i]);
for(ll i=;i<=n;i++)
{
ll k=;
for(ll j=;j<=m;j++)
{
pre[i][j]=j;
if(a[i]>b[j]&&d[j]>d[k])k=j;
else if(a[i]==b[j]&&d[j]<d[k]+)
{
d[j]=d[k]+;
pre[i][j]=k;//当i是第一个,且i与某个匹配时,i的pre与i-1(0)的pre相同了
if(!k)pre[i][j]=INF;
}
}
}
ll k=,mx=;
for(ll i=;i<=m;i++)
if(d[i]>mx)mx=d[i],k=i;
printf("%lld\n",mx);
print(n,k);
}

POJ2127 LICS模板的更多相关文章

  1. 最长公共子序列模板(LCS)和LICS模板

    递归式: 实例图解: 代码: #include<stdio.h> #include<string.h> ; int dp[N][N],f[N][N]; char a[N],b[ ...

  2. 最长公共上升子序列(LICS) 模板

    void LICS() { ;i<=n;i++) { ; ;j<=n;j++) { if (a[i]==b[j]) f[i][j]=ma+; ][j]; ][j]>ma) ma=f[ ...

  3. HDU 1423 LICS 模板

    http://acm.hdu.edu.cn/showproblem.php?pid=1423 4.LICS.O(lena * lenb) 设dp[i][j]表示a[]的前i项,以b[]的第j项结尾时, ...

  4. HDU1423:Greatest Common Increasing Subsequence(LICS)

    Problem Description This is a problem from ZOJ 2432.To make it easyer,you just need output the lengt ...

  5. Jade模板引擎让你飞

    写在前面:现在jade改名成pug了 一.安装 npm install jade 二.基本使用 1.简单使用 p hello jade! 渲染后: <p>hello jade!</p ...

  6. ABP入门系列(2)——通过模板创建MAP版本项目

    一.从官网创建模板项目 进入官网下载模板项目 依次按下图选择: 输入验证码开始下载 下载提示: 二.启动项目 使用VS2015打开项目,还原Nuget包: 设置以Web结尾的项目,设置为启动项目: 打 ...

  7. CMS模板应用调研问卷

    截止目前,已经有数十家网站与我们合作,进行了MIP化改造,在搜索结果页也能看到"闪电标"的出现.除了改造方面的问题,MIP项目组被问到最多的就是:我用了wordpress,我用了织 ...

  8. PHP-自定义模板-学习笔记

    1.  开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2.  整体架构图 ...

  9. 【原创分享·微信支付】C# MVC 微信支付之微信模板消息推送

    微信支付之微信模板消息推送                    今天我要跟大家分享的是“模板消息”的推送,这玩意呢,你说用途嘛,那还是真真的牛逼呐.原因在哪?就是因为它是依赖微信生存的呀,所以他能不 ...

随机推荐

  1. OC MRC之 @property参数(代码分析)

    第一部分 // // main.m // 04-@property参数 // // Created by apple on 13-8-9. // Copyright (c) 2013年 itcast. ...

  2. 【转】ASP.NET Core API 版本控制

    几天前,我和我的朋友们使用 ASP.NET Core 开发了一个API ,使用的是GET方式,将一些数据返回到客户端 APP.我们在前端进行了分页,意味着我们将所有数据发送给客户端,然后进行一些dat ...

  3. WEB-ERROR-PAGE

    首先需要在Web.xml文件中配置如下标签:     <error-page>        <error-code>404 </error-code>       ...

  4. 工作中遇到的oracle分页查询问题及多表查询相关

    在工作中,有时,我们会用到oracle分页查询.这时,就需要先了解oracle的rownum.rowmun是oracle的伪列,只能用符号(<.<=.!=),而不能用这些符号(>,& ...

  5. 离线部署 Cloudera Manager 5 和 CDH 5.12.1 及使用 CDH 部署 Hadoop 集群服务

    Cloudera Manager Cloudera Manager 分为两个部分:CDH和CM. CDH是Cloudera Distribution Hadoop的简称,顾名思义,就是cloudera ...

  6. L1-025 正整数A+B

    题的目标很简单,就是求两个正整数A和B的和,其中A和B都在区间[1,1000].稍微有点麻烦的是,输入并不保证是两个正整数. 输入格式: 输入在一行给出A和B,其间以空格分开.问题是A和B不一定是满足 ...

  7. ORACLE telnet 1521 不通及ORA-12514: TNS: 监听程序当前无法识别连接描述符中请求的服务的解决

    服务器上安装了oracle11g , 防火墙上已经增加1521 入站规则.但是内网客户端配置好了TNS无法连接.telnet 1521 不通. 需要在服务器上\product\10.2.0\db_1\ ...

  8. mysql5.7高可用架构之MHA

    一.MHA简介 MHA(Master High Availability)目前在mysql高可用方面比较成熟.是一套优秀的作为 mysql高可用性环境下故障切换和主从提升的高可用软件.在MySQL故障 ...

  9. happypack 进一步 优化 build速率

    1.webpack.base.conf.js 使用happypack的正确姿势: 'use strict' const path = require('path') const utils = req ...

  10. Guided Image Filtering

    在图像滤波中,人们最希望的就是可以将图像中的噪声过滤掉的同时,能够让边缘尽可能的保持.噪声属于高频信号,而边缘其实也是一种高频信号,所以一般的滤波器,比如高斯模糊,均值模糊,都是一种低通滤波器,能够将 ...