2014百度之星预赛(第二场)——Best Financing
2014百度之星预赛(第二场)——Best Financing
限制条件:
1<=n<=2500
1<=m<=2500
对于随意i(0<=i<n),1<=dates[i]<=100000,1<=earnings[i]<=100000, dates中无反复元素。
对于随意i(0<=i<m),1<=start[i]<finish[i]<=100000, 1<=interest_rates[i]<=100。
每组数据格式例如以下:
第一行是n m
之后连续n行,每行为两个以空格分隔的整数,依次为date和earning
之后连续m行,每行为三个以空格分隔的整数,依次为start, finish和interest_rate
Case #i:
收益数值,保留小数点后两位,四舍五入。
2
1 2
1 10000
1 100 5
50 200 10
2 2
1 10000
5 20000
1 5 6
5 9 7
Case #1:
1000.00
Case #2:
2700.00
正确的题意是:
告诉你n个时间点,这些时间点你会得到若干的钱.
然后告诉你m个时间段,以及时间段相应的利率(百分比).
问最后最多能够得到多少钱.
注意事项
首先收益不能用于购买
当天得到钱后当前能够花出去,也就是当天finish的当天可用于购买.
分析
理解题意后,心中会想到这是道DP题.
然后看看每一个时间点得到的钱,貌似他们之间是相互独立的.
实际上看到这个是独立的后。就非常好做了.
对于某个时间点的钱,我们随着时间的向后流动,会遇到一些时间段.
对于遇到的时间段。我们有两个选择:1.买; 2.不买.
买了我们的时间就移动到这个时间段的结束时间,不买了我们的时间移动到下一刻.
最后得到的钱是: 当前钱 * 选择的时间段的利率的和.
建议自己画一个图看看。或者自己心里面想想.
因为我们的目标是是收益最大,也就是是选择的时间段的利率和最大.
这个问题能够轻松的写出状态转移方程:
dp[ i ] = max( dp[i], dp[j] + rate[i, j]);
当中 dp[ i ] 代表 i 时间点到终于时间的路线上最大的利率和, dp[i] 的初始值能够是 dp[i + 1], 即不选择以这个时间点開始的时间段.
rate[i, j] 代表有个从 i 到 j 的时间段,且这个时间段的利率是 rate[i, j].
这样我们从后向前扫描一遍就能够预处理全部时间点到终于时间的最大利率.
然后我们用当前时间的钱 乘以 当前时间的最优利率和就是当前的最大利益.
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define MAX 100005 using namespace std; typedef struct Money
{
int dates;
int earnings;
}Money; typedef struct Earn
{
int start;
int finish;
int rate;
}Earn; bool cmp(const Earn &l,const Earn &r)
{
return l.start<r.start;
} int dp[MAX];
Money money[MAX];
Earn earn[MAX];
int n,m,maxtime;
long long ans; void DP()
{
memset(dp,0,sizeof(dp));
m--;
for(int i=maxtime;i>=0;i--)
{
dp[i]=dp[i+1];
while(m>=0&&i==earn[m].start)
{
dp[i]=max(dp[i],dp[earn[m].finish]+earn[m].rate);
m--;
}
}
} int main(int argc,char *argv[])
{
int t;
scanf("%d",&t);
for(int i=1;i<=t;i++)
{
scanf("%d%d",&n,&m);
maxtime=0;
for(int j=0;j<n;j++)
{
scanf("%d%d",&money[j].dates,&money[j].earnings);
maxtime=max(maxtime,money[j].dates);
}
for(int k=0;k<m;k++)
{
scanf("%d%d%d",&earn[k].start,&earn[k].finish,&earn[k].rate);
maxtime=max(maxtime,earn[k].finish);
}
sort(earn,earn+m,cmp);
DP();
ans=0;
for(int j=0;j<n;j++)
ans+=money[j].earnings*dp[money[j].dates];
printf("Case #%d:\n",i);
printf("%I64d.%02I64d\n",ans/100,ans%100);
}
return 0;
}
2014百度之星预赛(第二场)——Best Financing的更多相关文章
- 2014百度之星初赛第二场hdu 4831 Scenic Popularity
Scenic Popularity Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others ...
- HDU4828 Grids 2014百度之星预赛问题解决
看看Catalan数的公式:为 Catalan(n) = C(2n, n) / n+1 = C(2n, n) - C(2n, n-1); (公式0) 然后利用全排序表达:Catalan(n) = (2 ...
- 2014百度之星资格赛——Disk Schedule
2014百度拥有明星格比赛--Disk Schedule Problem Description 有非常多从磁盘读取数据的需求,包含顺序读取.随机读取. 为了提高效率.须要人为安排磁盘读取. 然而.在 ...
- 2014 百度之星 题解 1004 Labyrinth
Problem Description 度度熊是一仅仅喜欢探险的熊,一次偶然落进了一个m*n矩阵的迷宫,该迷宫仅仅能从矩阵左上角第一个方格開始走,仅仅有走到右上角的第一个格子才算走出迷宫,每一次仅仅能 ...
- 2014 CodingTrip - 携程编程大赛 (预赛第二场)
1001: 食物链(poj1182),直接贴代码,稍作可过 并查集 // // main.cpp // 携程1 // // Created by zhang on 14-4-11. // Copyri ...
- 2014年百度之星资格赛第二题Disk Schedule
Problem Description 有非常多从磁盘读取数据的需求,包含顺序读取.随机读取.为了提高效率,须要人为安排磁盘读取. 然而,在现实中,这样的做法非常复杂. 我们考虑一个相对简单的场景. ...
- 2014百度之星第二题Disk Schedule(双调欧几里得旅行商问题+DP)
Disk Schedule Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) To ...
- sql注入用<>绕过被过滤的select ——百度杯9月第二场SQL
题目提示SQL注入,打开源代码发现<!--SELECT * FROM info WHERE id=1--> 尝试union select 1,2,3提示inj code! 经过多次尝试之后 ...
- 2014百度之星资格赛—— Xor Sum(01字典树)
Xor Sum Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 132768/132768 K (Java/Others) Total ...
随机推荐
- 在ubuntu安装Phabricator(转)
前言: Phabricator是facebook团队进行codereview的一个工具,是基于php进行开发的.界面简洁优雅,是团队做代码评审的好帮手.个人认为,是当前最好的code review平台 ...
- 公司需求知识自学-Oracle的Package的作用及用法
Oracle的Package的作用 简化应用设计.提高应用性能.实现信息隐藏.子程序重载. 1.Oracle的Package除 了把存储过程放到一堆儿以外还有没有其他的作用(好处)? 你不觉得把存储过 ...
- 【JAVA学习】“-Xmx1024m -Xms1024m -Xmn512m -Xss256k”——Java执行參数(转)
年轻代 年老代概念 http://jefferent.iteye.com/blog/1123677 JVM的堆的内存, 是通过以下面两个參数控制的 -Xms 最小堆的大小, 也就是当你的虚拟机启动后 ...
- .NET 单点登录
<appSettings> <!--是否启用单点登录接口--> <add key="IsStartCas" value="f ...
- Android asynctask使用
继承asynctask,有三个參数 三个參数的含义是第一个表示输入參数.第二个为progress,表示当前的进度,第三个为doInbackground 返回值 须要一个參数传入url,返回一个r ...
- jQuery回到顶部插件jQuery GoUp
插件描写叙述 jQuery GoUp!是一个简单的jQuery插件,让你的网页用户直接回到顶部. 用法很easy 引用jquery库和jquery.goup.min.js到你的页面 <scrip ...
- AMD宣布裁员7% 约710员工将失去工作
10 月 17 日.美国芯片生产商 AMD 周四宣布将裁员7%.并公布了不及预期的第四季度业绩展望.这将是 AMD 自 2011 年以来的第三轮大裁员. 就在一周之前,AMD 宣布罗瑞德(Rory R ...
- EXE文件结构和读取方法
一.EXE文件概念 EXE File英文全名executable file .译作可运行文件,可移植可运行 (PE) 文件格式的文件,它能够载入到内存中.并由操作系统载入程序运行,是可在操作系统存储空 ...
- Form表单中的action路径问题
今天刚接触web,在用jsp和servlet做一个简单的登陆的时候在Form表单action属性和method属性的一些问题: 我遇到的是Form表单提交到servelet处理时遇到的问题: (1 ...
- CodeBlocks暴力恢复默认设置
昨天,我不知道怎么去CodeBlocks干净的界面使自己都不知道怎么走.然后找到默认设置恢复方法,找不到.然后,我用了一个恢复方法暴力,卸载重装,有一点须要注意.卸载后CodeBlocks的配置文件还 ...