题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=1160

题意:两个子序列 一个是升序,一个是降序,求最长的子序列是多长,并输出路径。(答案不唯一)

思路都是一样的,不断的更新当前值,优化之前的值,只不过还要记录一下路径。

代码:(注释应该就可以看得懂了)//这注释,我给自己满分。。

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
using namespace std;
#define INF 0x3f3f3f3f
const int maxn=1e6+; struct mice
{
int w,v,r,l; ///分别是体重,速度,位置,它下一个小鼠的位置
} m[maxn];
int dp[maxn]; ///dp代表到第i位老鼠的时候,排序能达到的最大长度 int cmp(mice a,mice b) ///体重降序排列,速度升序排列
{
if(a.w==b.w) return a.v<b.v;
else return a.w>b.w;
} int main()
{
int x,y,k=;
while(scanf("%d%d",&x,&y)==)
{
k++;
m[k].w=x;
m[k].v=y;
m[k].r=k;
m[k].l=;
}
sort(m+,m++k,cmp);
memset(dp,,sizeof(dp)); m[].w=INF; ///初始化m[0];
m[].v=;
m[].r=;
m[].l=; int ans=; for(int i=; i<=k; i++)
{
for(int j=; j<i; j++)
{
if(m[j].w>m[i].w && m[j].v<m[i].v)
{
if(dp[j]+>=dp[i]) ///dp[j]>=dp[i]时很好理解
{ ///那么dp[j]+1==dp[i]呢,就是使序列等长时,当前的体重值最小;
dp[i]=dp[j]+; ///长度+1
m[i].l=j; ///排好顺序后,第i只老鼠的下只老鼠是j;
if(dp[i]>dp[ans]) ans=i; ///找到当前长度的最大时的位置
}
} ///因为体重是降序排列,所以越往后i就可能是排在最前面的
} ///其实这就是一个插入的过程
}
printf("%d\n",dp[ans]);
while(m[ans].l!=) ///i越大,位置越靠前,所以从m[ans].r 开始输出。
{
printf("%d\n",m[ans].r); ///输出当前位置的原本位置
ans=m[ans].l; ///找到下一个位置
}
printf("%d\n",m[ans].r); ///输出排序最后一个位置的原本位置
return ;
}

代码2:

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
using namespace std;
#define INF 0x3f3f3f3f
const int maxn=1e6+; struct mice
{
int w,v,r,l; ///分别是体重,速度,位置,它下一个小鼠的位置
} m[maxn];
int dp[maxn]; ///dp代表到第i位老鼠的时候,排序能达到的最大长度 int cmp(mice a,mice b) ///体重降序排列,速度升序排列
{
if(a.w==b.w) return a.v<b.v;
else return a.w>b.w;
} int main()
{
int x,y,k=;
while(scanf("%d%d",&x,&y)==)
{
k++;
m[k].w=x;
m[k].v=y;
m[k].r=k;
m[k].l=;
}
sort(m+,m++k,cmp);
memset(dp,,sizeof(dp)); m[].w=INF; ///初始化m[0];
m[].v=;
m[].r=;
m[].l=; int ans=; for(int i=; i<=k; i++)
{
for(int j=; j<i; j++)
{
if(m[j].w>m[i].w && m[j].v<m[i].v)
{
if(dp[j]+>dp[i])
{
dp[i]=dp[j]+; ///长度+1
m[i].l=j; ///排好顺序后,第i只老鼠的下只老鼠是j;
if(dp[i]>dp[ans]) ans=i; ///找到当前长度的最大时的位置
}
} ///因为体重是降序排列,所以越往后i就可能是排在最前面的
} ///其实这就是一个插入的过程
}
printf("%d\n",dp[ans]);
while(m[ans].l!=) ///i越大,位置越靠前,所以从m[ans].r 开始输出。
{
printf("%d\n",m[ans].r); ///输出当前位置的原本位置
ans=m[ans].l; ///找到下一个位置
}
printf("%d\n",m[ans].r); ///输出排序最后一个位置的原本位置
return ;
}

hdu1160 LIS变形的更多相关文章

  1. 九度 1557:和谐答案 (LIS 变形)

    题目描述: 在初试即将开始的最后一段日子里,laxtc重点练习了英语阅读的第二部分,他发现了一个有意思的情况.这部分的试题最终的答案总是如下形式的:1.A;2.C;3.D;4.E;5.F.即共有六个空 ...

  2. hdu 1087(LIS变形)

    Super Jumping! Jumping! Jumping! Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 ...

  3. UVA 437 巴比伦塔 【DAG上DP/LIS变形】

    [链接]:https://cn.vjudge.net/problem/UVA-437 [题意]:给你n个立方体,让你以长宽为底,一个个搭起来(下面的立方体的长和宽必须大于上面的长和宽)求能得到的最长高 ...

  4. HDU-1160.FatMouse'sSpeed.(LIS变形 + 路径打印)

    本题大意:给定一定数量的数对,每个数保存着一只老鼠的质量和速度,让你求出一个最长序列,这个序列按照质量严格递增,速度严格递减排列,让你输出这个序列的最长长度,并且输出组成这个最长长度的序列的对应的老鼠 ...

  5. UVa 1471 (LIS变形) Defense Lines

    题意: 给出一个序列,删掉它的一个连续子序列(该子序列可以为空),使得剩下的序列有最长的连续严格递增子序列. 分析: 这个可以看作lrj的<训练指南>P62中讲到的LIS的O(nlogn) ...

  6. hdu5773--The All-purpose Zero(LIS变形)

    题意:给一个非负整数的数列,其中0可以变成任意整数,包括负数,求最长上升子序列的长度. 题解:LIS是最简单的DP了,但是变形之后T^T真的没想到.数据范围是10^5,只能O(nlogn)的做法,所以 ...

  7. UVA1471( LIS变形)

    这是LIS的变形,题意是求一个序列中去掉某个连续的序列后,能得到的最长连续递增序列的长度. 用DP的解法是:吧这个序列用数组a来记录,再分别用两个数组f记录以i结尾的最长连续递增序列的长度,g[i]记 ...

  8. POJ 1836-Alignment(DP/LIS变形)

    Alignment Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 13465   Accepted: 4336 Descri ...

  9. poj 1836 LIS变形

    题目链接http://poj.org/problem?id=1836 Alignment Time Limit: 1000MS   Memory Limit: 30000K Total Submiss ...

随机推荐

  1. 插头DP专题

    建议入门的人先看cd琦的<基于连通性状态压缩的动态规划问题>.事半功倍. 插头DP其实是比较久以前听说的一个东西,当初是水了几道水题,最近打算温习一下,顺便看下能否入门之类. 插头DP建议 ...

  2. 【leetcode】Text Justification(hard) ☆

    Given an array of words and a length L, format the text such that each line has exactly L characters ...

  3. HTML认识

    1.1 认识什么是纯文本文件 txt window自带有一个软件,叫做记事本,记事本保存的格式TXT,就是英文text的缩写,术语上称呼为"纯文本文件" TXT文件,只能保存文本内 ...

  4. August 14th, Week 34th Sunday, 2016

    To live is to function, that is all there is in living. 活着就要发挥作用,这就是生活的全部内容. I often joke that my dr ...

  5. JS判断IE版本并在页面显示内容

    <script type="text/javascript"> var isIE = function (ver) { var b = document.createE ...

  6. iOS开发人员不容错过的10大工具

    内容简介 1.iOS简介 2.iOS开发十大实用工具之开发环境 3.iOS开发十大实用工具之图标设计 4.iOS开发十大实用工具之原型设计 5.iOS开发十大实用工具之演示工具 6.iOS开发十大实用 ...

  7. 与你相遇好幸运,Tippecanoe用法

    //todo 基本用法: tippecanoe -o file.mbtiles [file.json ...] 参数解释: <必须>   -o myFileName.mbtiles  或者 ...

  8. async/await 异步编程(转载)

    转载地址:http://www.cnblogs.com/teroy/p/4015461.html 前言 最近在学习Web Api框架的时候接触到了async/await,这个特性是.NET 4.5引入 ...

  9. 重温WCF之群聊天程序(十)

    完成的效果图: 服务器端代码: using System; using System.Collections.Generic; using System.Linq; using System.Serv ...

  10. 图结构练习——判断给定图是否存在合法拓扑序列(dfs算法(第一个代码),邻接矩阵(前两个代码),邻接表(第三个代码))

    sdut 2140 图结构练习——判断给定图是否存在合法拓扑序列 Time Limit: 1000ms   Memory limit: 65536K  有疑问?点这里^_^ 题目描述  给定一个有向图 ...