Description

设有一个整数的序列:b1,b2,…,bn,对于下标i1<i2<…<im,若有bi1≤bi2≤…≤bim
则称存在一个长度为m的不下降序列。

现在有n个数,请你求出这n个数的最长不下降序列的长度及有多少个最长不下降序列

Input

第一行为一个整数n (n < 104

第二行有n个整数,数与数之间使用空格间隔

Output

第一行,最长不下降序列的长度

第二行,能构成多少个最长不下降序列(数字相同,位置不同算不同)

Sample Input

7
1 4 3 2 6 5 7

Sample Output

4
 
这道题综合了求最长不降子序列长度和个数,是一道不折不扣的好题。
需要一定的动归基础,0基础同学请自动回避本博客。
 
定义两个数组,dp数组表示以i结尾的最长不降子序列长度,
len数组表示以i结尾的最长不降子序列的个数。
 
我们处理第一问的时候,在输出上加一些处理。
求最长不降子序列的时候,先初始化dp[i]=1;不需要解释。
然后内层循环从1到i-1开始扫。如果符合条件(a[j]<=a[i])
就转移,dp[i]取dp[i]和dp[j]+1的较大值。
这些都不需要解释,。
然后定义标记变量vis,初值一定要设置1。
从头扫,不断更新最长的长度。
最后求出最最最长的长度dp[vis]输出。
 
然后是本题的重头戏。
第二次动归。
首先是初值,初值要设置成1,前提条件是dp[i]得等于1.因为只有长度为1的最长不降子序列的个数是唯一确定的,
然后可以开始扫描了。
这里要注意这个条件,着重着重着重!!!理解!!
dp[j]+1==dp[i]
为什么呢??
注意题面,数字相同位置不同算不同,就是这个意思。
好好理解
然后就可以输出答案了,原理和上面的大同小异。
 
代码:
#include<cstdio>
#include<algorithm>
using namespace std;
int n,ans,vis;
int a[];
int dp[];//表示以i结尾的最长不下降序列的长度。
int len[];//表示以i为结尾的最长不降序列的个数.
int main()
{
scanf("%d",&n);
for(int i=;i<=n;i++)
scanf("%d",&a[i]);
for(int i=;i<=n;i++)
{
dp[i]=;
for(int j=;j<i;j++)
if(a[j]<=a[i])
dp[i]=max(dp[j]+,dp[i]);
}
vis=;
for(int i=;i<=n;i++)
if(dp[i]>dp[vis])
vis=i;
printf("%d\n",dp[vis]);
for(int i=;i<=n;i++)
{
if(dp[i]==)
len[i]=;
else
for(int j=;j<i;j++)
if(a[j]<=a[i] && dp[j]+==dp[i])
len[i]+=len[j];
}
for(int i=;i<=n;i++)
if(dp[i]==dp[vis])
ans+=len[i];
printf("%d",ans);
return ;
}

JDOJ 1946 求最长不下降子序列个数的更多相关文章

  1. JDOJ 1929: 求最长不下降序列长度

    JDOJ 1929: 求最长不下降序列长度 JDOJ传送门 Description 设有一个正整数的序列:b1,b2,-,bn,对于下标i1<i2<-<im,若有bi1≤bi2≤-≤ ...

  2. P1020 导弹拦截(nlogn求最长不下降子序列)

    题目描述 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能高于前一发的高度.某天,雷达捕捉到敌国的导弹 ...

  3. 算法进阶 (LIS变形) 固定长度截取求最长不下降子序列【动态规划】【树状数组】

    先学习下LIS最长上升子序列 ​ 看了大佬的文章OTZ:最长上升子序列 (LIS) 详解+例题模板 (全),其中包含普通O(n)算法*和以LIS长度及末尾元素成立数组的普通O(nlogn)算法,当然还 ...

  4. 求最长不下降子序列(nlogn)

    最长递增子序列问题:在一列数中寻找一些数,这些数满足:任意两个数a[i]和a[j],若i<j,必有a[i]<a[j],这样最长的子序列称为最长递增子序列. 设dp[i]表示以i为结尾的最长 ...

  5. Monkey and Banana(dp,求最长的下降子序列)

    A group of researchers are designing an experiment to test the IQ of a monkey. They will hang a bana ...

  6. tyvj 1049 最长不下降子序列 n^2/nlogn

    P1049 最长不下降子序列 时间: 1000ms / 空间: 131072KiB / Java类名: Main 描述 求最长不下降子序列的长度 输入格式 第一行为n,表示n个数第二行n个数 输出格式 ...

  7. 最长不下降子序列//序列dp

    最长不下降子序列 时间: 1000ms / 空间: 131072KiB / Java类名: Main 描述 求最长不下降子序列的长度 输入格式 第一行为n,表示n个数第二行n个数 输出格式 最长不下降 ...

  8. 【tyvj】P1049 最长不下降子序列

    时间: 1000ms / 空间: 131072KiB / Java类名: Main 描述 求最长不下降子序列的长度 输入格式 第一行为n,表示n个数 第二行n个数 输出格式 最长不下降子序列的长度 测 ...

  9. 最长不下降子序列nlogn算法详解

    今天花了很长时间终于弄懂了这个算法……毕竟找一个好的讲解真的太难了,所以励志我要自己写一个好的讲解QAQ 这篇文章是在懂了这个问题n^2解决方案的基础上学习. 解决的问题:给定一个序列,求最长不下降子 ...

随机推荐

  1. 常用的ROS命令

    在这里记一下,以免以后忘记了. ------------------------------------------------------------------------------------ ...

  2. Angular命令和基础操作

    本文档假设你已经熟悉了 HTML,CSS,JavaScript和来自最新标准的一些知识,比如类和模块. 一.Angular命令 命令语法: 大多数命令以及少量选项,会有别名.别名会显示在每个命令的语法 ...

  3. eclipse 离线安装SVN插件(支持eclipse201909)

      1.情景展示 重装eclipse后,按照网上的在线安装方法,SVN始终安装失败,之前的离线SVN包也不能用. 2.解决方案 SVN离线包下载地址:http://subclipse.tigris.o ...

  4. Pencil 基于Electron的GUI原型工具之菜单再探

    为什么要重试呢? 主要是觉得Pencil这个工具还是比较有价值.就像Linus对Linux下分发版的态度"让用户有选择"一样,在现在这个Sass服务.Web服务化越来越普遍越便利的 ...

  5. HTML连载31-制作一个百度首页

    一. 我们制作一个百度首页作为练习,可直接复制该代码保存后缀名为.html来查看 <!DOCTYPE html> <html lang="en"> < ...

  6. BFS(四):搜索状态判重

    在采用广度优先算法进行搜索时,一个需要重点注意的是在搜索过程中判重和去重.前面介绍的几个例子中,判重都较简单,如采用vis[]数组,若vis[i]==0,则i未访问过,i入队列:若vis[i]!=0, ...

  7. LeetCode 733: 图像渲染 flood-fill

    题目: 有一幅以二维整数数组表示的图画,每一个整数表示该图画的像素值大小,数值在 0 到 65535 之间. An image is represented by a 2-D array of int ...

  8. NXP官方的i.mx6ul板级uboot源码适配

    1.前言 CoM-P6UL是盈鹏飞科技有限公司基于NXP原厂I.MX6UL芯片生产研发的核心板,本文将对CoM-P6UL适配NXP的基于Linux4.1.15版本的uboot板级源码. 2.开发环境 ...

  9. linux基础学习路线&review

    linux基础学习网址: https://www.runoob.com/linux/linux-tutorial.html 比较重点的是这个启动过程的介绍学习:https://www.runoob.c ...

  10. CompletableService

    public class CompletableServiceTest { public static void main(String[] args) throws ExecutionExcepti ...