题目链接


Solution

似乎就是个很简单的最长不上升子序列输出方案.

但是有一个很艹蛋的条件: 不同方案选择价格必须不同.

且其股票价格不保证不相同.

\(f[i]\) 代表以第 \(i\) 天结尾的不上升子序列的长度.

其实我们可以推出一个条件 : 相同的两个股票价格同时出现,后者的方案里面一定包括前者的.

这也是我们按平常做法多出来的方案数.

所以我们可以直接在 DP 的时候记录一个 \(g[i][j]\) 代表在 \(i\) 时由最后一个价值为 \(j\) 的已经累加的次数.

然后每次加上的便是 \(g[v][j]-g[i][j]\). 其中 \(v\) 为可以转移到 \(i\) 最优方案的节点.

Code

#include<bits/stdc++.h>
using namespace std;
const int maxn=5008;
int w[maxn],n;
int f[maxn];
map<int,int>g[maxn];
map<int,int>v;
int ans,ans_num;
int main()
{
scanf("%d",&n); w[0]=0x3f3f3f3f;
for(int i=1;i<=n;i++)
scanf("%d",&w[i]);
g[0][w[0]]=1; f[0]=0;
for(int i=1;i<=n;i++)
{
for(int j=0;j<i;j++)
if(w[i]<w[j])
if(f[j]+1>f[i])
f[i]=f[j]+1; for(int j=0;j<i;j++)
if(w[i]<w[j])
if(f[j]+1==f[i])
{
g[i][w[i]]+=(g[j][w[j]]-g[i][w[j]]);
g[i][w[j]]=g[j][w[j]];
}
}
for(int i=1;i<=n;i++)
if(f[i]>ans)ans=f[i];
for(int i=1;i<=n;i++)
if(f[i]==ans)
{
ans_num+=g[i][w[i]]-v[w[i]];
v[w[i]]=g[i][w[i]];
}
cout<<ans<<' '<<ans_num;
return 0;
}

P1108 低价购买 (动态规划)的更多相关文章

  1. 洛谷 P1108 低价购买

    P1108 低价购买 标签 动态规划 难度 提高+/省选- 题目描述 "低价购买"这条建议是在奶牛股票市场取得成功的一半规则.要想被认为是伟大的投资者,你必须遵循以下的问题建议:& ...

  2. 洛谷 P1108 低价购买 解题报告

    P1108 低价购买 题目描述 "低价购买"这条建议是在奶牛股票市场取得成功的一半规则.要想被认为是伟大的投资者,你必须遵循以下的问题建议:"低价购买:再低价购买&quo ...

  3. P1108 低价购买 (DP)

    题目 P1108 低价购买 解析 这题做的我身心俱惫,差点自闭. 当我WA了N发后,终于明白了这句话的意思 当二种方案"看起来一样"时(就是说它们构成的价格队列一样的时候),这2种 ...

  4. P1108 低价购买——最长下降子序列+方案数

    P1108 低价购买 最长下降子序列不用多讲:关键是方案数: 在求出f[i]时,我们可以比较前面的f[j]; 如果f[i]==f[j]&&a[i]==a[j] 要将t[j]=0,去重: ...

  5. 洛谷P1108 低价购买[DP | LIS方案数]

    题目描述 “低价购买”这条建议是在奶牛股票市场取得成功的一半规则.要想被认为是伟大的投资者,你必须遵循以下的问题建议:“低价购买:再低价购买”.每次你购买一支股票,你必须用低于你上次购买它的价格购买它 ...

  6. 洛谷P1108 低价购买

    题目描述 “低价购买”这条建议是在奶牛股票市场取得成功的一半规则.要想被认为是伟大的投资者,你必须遵循以下的问题建议:“低价购买:再低价购买”.每次你购买一支股票,你必须用低于你上次购买它的价格购买它 ...

  7. P1108 低价购买(DP)

    题目描述 "低价购买"这条建议是在奶牛股票市场取得成功的一半规则.要想被认为是伟大的投资者,你必须遵循以下的问题建议:"低价购买:再低价购买".每次你购买一支股 ...

  8. 洛谷P1108 低价购买题解

    看到"你必须用低于你上次购买它的价格购买它",有没有想到什么?没错,又是LIS,倒过来的LIS,所以我们只要把读入的序列倒过来就可以求LIS了,第一问解决. 首先要厘清的是,对于这 ...

  9. P1108 低价购买

    传送门 思路: 对于第一问很容易看出是求最长下降子序列,N2 的暴力就可解决.而第二问是求最优方案数(且不重复),需要判重.可以在求解最长下降子序列的基础上增开一个数组 g ,g[ i ] 表示以 i ...

随机推荐

  1. mybatis(一):思维导图

  2. Kunernetes集群架构与组件

    架构如图: master节点:主要是集群控制面板的功能,来管理整个集群,包括全局的角色,调度,都是在master节点进行控制 有三个组件: API Server:  是 k8s提供的一个统一入口,它是 ...

  3. SQLServer死锁

    死锁的四个必要条件:互斥条件(Mutual exclusion):资源不能被共享,只能由一个进程使用.请求与保持条件(Hold and wait):已经得到资源的进程可以再次申请新的资源.非剥夺条件( ...

  4. 新手 WordPress主题制作全过程

    WordPress主题制作全过程(一):基础准备 前言: 我想大多数使用WordPress的朋友都喜欢去尝试新的主题,但是换来换去,总是找不到那么一款适合自己的,让人很郁闷.于是很多人萌生了修改现有主 ...

  5. 20180904 定时器setTimeout和setInterval回调问题

    引用: setTimeout和setInterval两者的区别 setTimeout和setInterval的优缺点 setTimeout和setInterval详解 两者的作用都是在定时多少毫秒后回 ...

  6. .pyc文件的结构体PyCodeObject

    python执行程序时生成的pyc文件里面是,PyCodeObject 的结构体构成,每个命名空间(函数名.import模块等)都会形成一个core block,一个python程序的所有命名空间生成 ...

  7. MYSQL存储过程,函数,光标

    存储过程 MySQL中,创建存储过程的基本形式如下: CREATE PROCEDURE sp_name ([proc_parameter[,...]]) [characteristic ...] ro ...

  8. usb hub 设备流程图

    在此处负责而来:http://blog.csdn.net/xuelin273/article/details/38646851  下面的转载于:http://blog.csdn.net/qianguo ...

  9. LeetCode(172)Factorial Trailing Zeroes

    题目 Given an integer n, return the number of trailing zeroes in n!. Note: Your solution should be in ...

  10. Cheese Aizu - 0558 (搜索题)

    Time limit8000 ms Memory limit131072 kB チーズ () 問題 今年も JOI 町のチーズ工場がチーズの生産を始め,ねずみが巣から顔を出した.JOI 町は東西南北に ...