洛谷1108 低价购买

题目描述

“低价购买”这条建议是在奶牛股票市场取得成功的一半规则。要想被认为是伟大的投资者,你必须遵循以下的问题建议:“低价购买;再低价购买”。每次你购买一支股票,你必须用低于你上次购买它的价格购买它。买的次数越多越好!你的目标是在遵循以上建议的前提下,求你最多能购买股票的次数。你将被给出一段时间内一支股票每天的出售价(2^16范围内的正整数),你可以选择在哪些天购买这支股票。每次购买都必须遵循“低价购买;再低价购买”的原则。写一个程序计算最大购买次数。
这里是某支股票的价格清单:
日期  1  2  3  4  5  6  7  8  9 10 11 12
价格 68 69 54 64 68 64 70 67 78 62 98 87
最优秀的投资者可以购买最多4次股票,可行方案中的一种是: 
日期    2  5  6 10
价格   69 68 64 62

输入输出格式

输入格式:

第1行: N (1 <= N <= 5000),股票发行天数
第2行: N个数,是每天的股票价格。

输出格式:

输出文件仅一行包含两个数:最大购买次数和拥有最大购买次数的方案数(<=2^31)当二种方案“看起来一样”时(就是说它们构成的价格队列一样的时候),这2种方案被认为是相同的。

输入输出样例

输入样例#1:

BUYLOW.IN
12
68 69 54 64 68 64 70 67 78 62 98 87

输出样例#1:

BUYLOW.OUT
4 2

解题思路第一问就是最基本的最长下降子序列,问题的关键在第二问,这里我们可以采用一种贪心的思路,当发现两个值相等就把后面的那个值赋值为0,毕竟同样的大小,选前面的总是比选后面的要好啊
 1 var n,i,j,max,ans:longint;
 2     m,f,t:array[0..5000]of longint;
 3 begin
 4     readln(n);
 5     fillchar(f,sizeof(f),0);
 6     fillchar(t,sizeof(t),0);
 7     max:=0;
 8     for i:=1 to n do
 9     begin
10         read(m[i]);
11         for j:=1 to i-1 do
12         if (m[j]>m[i])and(f[j]>f[i]) then
13         f[i]:=f[j];
14         inc(f[i]);
15         if f[i]=1 then t[i]:=1;
16         for j:=1 to i-1 do
17         if (f[i]-1=f[j])and(m[j]>m[i]) then inc(t[i],t[j])
18         else if (m[j]=m[i])and(f[i]=f[j]) then t[j]:=0;    //类似这个样子
19         if f[i]>max then max:=f[i];
20     end;
21     ans:=0;
22     for i:=1 to n do
23     if f[i]=max then inc(ans,t[i]);
24     writeln(max,‘ ‘,ans);
25 end.   

 
时间: 2024-12-26 09:52:52

洛谷1108 低价购买的相关文章

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

题目描述 “低价购买”这条建议是在奶牛股票市场取得成功的一半规则.要想被认为是伟大的投资者,你必须遵循以下的问题建议:“低价购买:再低价购买”.每次你购买一支股票,你必须用低于你上次购买它的价格购买它.买的次数越多越好!你的目标是在遵循以上建议的前提下,求你最多能购买股票的次数.你将被给出一段时间内一支股票每天的出售价(2^16范围内的正整数),你可以选择在哪些天购买这支股票.每次购买都必须遵循“低价购买:再低价购买”的原则.写一个程序计算最大购买次数. 这里是某支股票的价格清单: 日期 1 2

入门动态规划 洛谷P1108 低价购买

P1108 低价购买 题目描述 "低价购买"这条建议是在奶牛股票市场取得成功的一半规则.要想被认为是伟大的投资者,你必须遵循以下的问题建议:"低价购买:再低价购买".每次你购买一支股票,你必须用低于你上次购买它的价格购买它.买的次数越多越好!你的目标是在遵循以上建议的前提下,求你最多能购买股票的次数.你将被给出一段时间内一支股票每天的出售价(2^16范围内的正整数),你可以选择在哪些天购买这支股票.每次购买都必须遵循"低价购买:再低价购买"的原则

洛谷1455 搭配购买(并查集)

洛谷1455 搭配购买 本题地址:http://www.luogu.org/problem/show?pid=1455 题目描述 明天就是母亲节了,电脑组的小朋友们在忙碌的课业之余挖空心思想着该送什么礼物来表达自己的心意呢?听说在某个网站上有卖云朵的,小朋友们决定一同前往去看看这种神奇的商品,这个店里有n朵云,云朵已经被老板编号为1,2,3,……,n,并且每朵云都有一个价值,但是商店的老板是个很奇怪的人,他会告诉你一些云朵要搭配起来买才卖,也就是说买一朵云则与这朵云有搭配的云都要买,电脑组的你觉

1108 低价购买

难度:提高+/省选- 题目类型:动规 提交次数:3(待定) 涉及知识:线性动规 题目描述 “低价购买”这条建议是在奶牛股票市场取得成功的一半规则.要想被认为是伟大的投资者,你必须遵循以下的问题建议:“低价购买:再低价购买”.每次你购买一支股票,你必须用低于你上次购买它的价格购买它.买的次数越多越好!你的目标是在遵循以上建议的前提下,求你最多能购买股票的次数.你将被给出一段时间内一支股票每天的出售价(2^16范围内的正整数),你可以选择在哪些天购买这支股票.每次购买都必须遵循“低价购买:再低价购买

洛谷P2983 [USACO10FEB]购买巧克力Chocolate Buying

题目描述 Bessie and the herd love chocolate so Farmer John is buying them some. The Bovine Chocolate Store features N (1 <= N <= 100,000) kinds of chocolate in essentially unlimited quantities. Each type i of chocolate has price P_i (1 <= P_i <= 1

洛谷P1455 搭配购买

题目描述 明天就是母亲节了,电脑组的小朋友们在忙碌的课业之余挖空心思想着该送什么礼物来表达自己的心意呢?听说在某个网站上有卖云朵的,小朋友们决定一同前往去看看这种神奇的商品,这个店里有n朵云,云朵已经被老板编号为1,2,3,--,n,并且每朵云都有一个价值,但是商店的老板是个很奇怪的人,他会告诉你一些云朵要搭配起来买才卖,也就是说买一朵云则与这朵云有搭配的云都要买,电脑组的你觉得这礼物实在是太新奇了,但是你的钱是有限的,所以你肯定是想用现有的钱买到尽量多价值的云. 输入输出格式 输入格式: 第1

洛谷—— P2983 [USACO10FEB]购买巧克力Chocolate Buying

https://www.luogu.org/problem/show?pid=2983 题目描述 Bessie and the herd love chocolate so Farmer John is buying them some. The Bovine Chocolate Store features N (1 <= N <= 100,000) kinds of chocolate in essentially unlimited quantities. Each type i of

洛谷——P1455 搭配购买

https://www.luogu.org/problem/show?pid=1455 题目描述 明天就是母亲节了,电脑组的小朋友们在忙碌的课业之余挖空心思想着该送什么礼物来表达自己的心意呢?听说在某个网站上有卖云朵的,小朋友们决定一同前往去看看这种神奇的商品,这个店里有n朵云,云朵已经被老板编号为1,2,3,……,n,并且每朵云都有一个价值,但是商店的老板是个很奇怪的人,他会告诉你一些云朵要搭配起来买才卖,也就是说买一朵云则与这朵云有搭配的云都要买,电脑组的你觉得这礼物实在是太新奇了,但是你的

LuoGu 1108 低价购买 LIS方案数

一句话题意:两个序列的LIS的长度和方案数 首先这里n方的应该是要比nlog的好的,因为还涉及到一个求方案 主要考虑下第二问, 不同的方案数应该怎么求 实际上 对于一个长为len的子序列, 它的方案数即为所有长为len-1的,且可以转移到它的子序列 (都是满足题意的)的方案数之和 这样就比较好办了,直接在原本的求LIS的转移里搞搞就行了. 那么答案就是所有长度为LIS的方案数之和了. 但是还有一个问题,这样的话根本没考虑方案是否重复. 那么怎么样把相同的去掉呢?? 我们把长度相等,当前对应位上的