USACO 滑雪课程
#include<cstdio>
#include<iostream>
using namespace std; int T,S,N,maxd;
int len[],lv[],next[],first[];//注意这个first要开到和极限时间一样
int mintime[];//表示在级别i的时候 能够滑的最短时间赛道
int dp[][]; int main()
{
freopen("ski.in","r",stdin);
freopen("ski.out","w",stdout);
//=========================
for(int i=;i<;i++) //预处理mintime 设成最大 这样才能求最小
{
mintime[i]=<<;
}
scanf("%d%d%d",&T,&S,&N);
//读入课程的信息 为了能实现记录同一时间出现多门课程的情况
//我们使用类似边信息表的思想 建立数组 len[i] 表示第i门课程持续时间
//next[i] 表示第i门课程的兄弟课程编号 就是开始时间一样的
//lv[i] 表示第i门课程上完达到的level
//first[i] 注意 i表示第i秒开始的课程编号
for(int i=,a,b,c;i<=S;i++)
{
scanf("%d%d%d",&a,&b,&c);
len[i]=b;
lv[i]=c;
next[i]=first[a];
first[a]=i;
maxd=max(maxd,c);
} //接下来读入滑雪赛道信息 我们知道要滑的尽量多 时间就要短
//所以要预处理下最短时间赛道 for(int i=,c,d;i<=N;i++)
{
scanf("%d%d",&c,&d);
for(int j=c;j<=;j++)
{
mintime[j]=min(mintime[j],d);
}
} //到这一步应该检查mintime数组到底对不对
//接下来进行递推操作 在上次说的状态转移方程基础上 我们要以时间i为单位
//枚举在i时间下的所有级别j的可能性 从左往右 在二维表上一列一列的更新
//简单说就是左边时间的状态想办法让右边的时间状态变得更大
//我们在dp二维表上进行运算 for(int i=;i<=T+;i++)
{
for(int j=;j<=;j++)
{
dp[i][j]=-;
}
} dp[][]=;
for(int i=;i<T;i++)
{
for(int j=;j<=;j++)
{
if(dp[i][j]==-) continue; dp[i+][j]=max(dp[i+][j],dp[i][j]);
dp[i+mintime[j]][j]=max(dp[i+mintime[j]][j],dp[i][j]+); int p=first[i];
while(p!=)
{
dp[i+len[p]][lv[p]]=max(dp[i+len[p]][lv[p]],dp[i][j]);
p=next[p];
}
}
}
int ans=-;
for(int i=;i<=maxd;i++)
{
ans=max(ans,dp[T][i]);
//cout<<dp[T][i]<<" "; 这里可以输出最后一行的答案看看正确性
}
printf("%d",ans); //=========================
fclose(stdin);
fclose(stdout);
return ;
}
农夫约翰想带着他的奶牛Bessie去佛罗里达滑雪,可是,Bessie的滑雪技术真是太差了。
她了解到滑雪学校全天提供滑雪课程,共有S(0 <= S <=100)个滑雪课程可供选择,课程i从时间M_i(1 <= M_i <= 10,000)开始,持续时间为L_i(1 <= L_i <= 10,000),学完该课程滑雪水平将提升至A_i(1 <= A_i <= 100),注意:滑雪水平的提升是绝对的,而不是累加的。
此外Bessie还买了一张滑雪练习场的地图,从图中可以看到练习场每个斜坡的详细情况:从坡上滑下来所需的时间D_i(1 <= D_i <= 10,000),以及滑这个坡所需要的水平等级C_i(1 <= C_i <= 100),为安全起见,只有滑雪水平高于该坡所要求的等级,才可以从这个坡滑下。
Bessie可以把她所有的时间都花在滑雪、上课上,当然她也可以去喝杯热可可,但前提是她必须得在滑雪学校待至时间T(1 <= T <= 10,000),这也意味着她的最后一趟滑坡行动不得超过这个时限。
请确定在这个时间段内,Bessie最多可以滑多少趟斜坡,假定她当天的起始水平为1。
输入格式:
第1行,三个空格隔开的整数:T,S,N;
第2~S+1行,第i+1行有三个空格隔开的整数M_i,L_i,A_i,描述了一个课程的情况;
第S+2~S+N+1行,第S+i+1行为两个空格隔开的整数,C_i,D_i,描述了一个斜坡的情况。
输出格式:
一行,一个整数,即在时限内Bessie能完成的滑坡的最大次数。
样例:
ski.in
10 1 2
3 2 5
4 1
1 3
ski.out
6
输出数据说明:
先滑一次第2个斜坡,然后在时间3去上课,上课至时间5,然后在时间结束之前可以再滑五次第1个斜坡,所以共6次滑坡。
提交地址 http://cogs.pro/cogs/problem/problem.php?pid=754
USACO 滑雪课程的更多相关文章
- 【USACO】滑雪课程
滑雪课程贝西去科罗拉多州去滑雪,不过还她不太会玩,只是个能力为 1 的渣渣.贝西从 0 时刻进入滑雪场,一到 T 时刻就必须离开.滑雪场里有 N 条斜坡,第 i 条斜坡滑行一次需要 Di 分钟,要求游 ...
- USACO 1.3.6 Ski Course Design[滑雪课程设计]
先说说思路: 这题比上一道坑人的wormholes简单多了!我一看到这题,“XXX设计”,还以为要用到什么dp呢,没想到是水题 用两层循环,第一层循环相差17中的上界,第二层遍历所有的山峰计算答案.并 ...
- 【LSGDOJ 1850】滑雪课程
题目描述 贝西去科罗拉多州去滑雪,不过还她不太会玩,只是个能力为 1 的渣渣.贝西从 0 时刻进入滑雪场,一到 T 时刻就必须离开.滑雪场里有 N 条斜坡,第 i 条斜坡滑行一次需要 D i 分钟,要 ...
- 【USACO2009 Open】滑雪课程ski
[USACO2009 Open]滑雪课程 Ski Lessons Time Limit: 1000 ms Memory Limit: 131072 KBytes Description 约翰请贝西去科 ...
- 洛谷 P3650 [USACO1.3]滑雪课程设计Ski Course Design
P3650 [USACO1.3]滑雪课程设计Ski Course Design 题目描述 农民约翰的农场里有N座山峰(1<=N<=1000),每座山都有一个在0到100之间的整数的海拔高度 ...
- Usaco 滑雪比赛 Bobsledding, 2009 Dec(dp)
Description 滑雪比赛bobsled 贝西参加了一场高山急速滑雪比赛,滑道总长度为 L.出发时,她的初速度为 1,贝西可以加速 或减速,每过 1 米,她能将速度增加 1.减少 1 或保持不变 ...
- [USACO精选] 第二章 动态规划(一)
#4 公司利润 2014-01-16 这真的是动归?怎么觉得有点贪心的心态在.时间复杂度O(N),空间复杂度O(1),轻松加愉快!唯一要注意的是ANS一开始要赋负值,因为最终答案可能是负的. ; va ...
- USACO Section 1.3 题解 (洛谷OJ P1209 P1444 P3650 P2693)
usaco ch1.4 sort(d , d + c, [](int a, int b) -> bool { return a > b; }); 生成与过滤 generator&& ...
- Luogu USACO Training 刷水记录
开个坑记录一下刷USACO的Training的记录 可能会随时弃坑 只有代码和做法简述 可能没有做法简述 [USACO1.1]你的飞碟在这儿Your Ride Is He… 模拟,细节已忘 #incl ...
随机推荐
- 《看板与Scrum》读书笔记
看板的朴素思想:在制品(work-in-progress, WIP)必须被限制 WIP上限和拉动式生产 1. Scrum与看板简述 Scrum:组织拆分,工作拆分,开发时间拆分,优化发布计划,过程优化 ...
- 使用ActionBar Tab
使用ActionBar Tab(地址) 本文实现将页面分为多个选项卡,并在每一个选项卡中显示一个ListView. 创建新Layout - ActionbarTab.axml, 并向页面中添加Fram ...
- android ImageView组件属性
adjustViewBounds :该属性为真时可以在调整ImageView边界时保持图片的纵横比例(需要与maxHeight 或maxWidth一起使用). scaleType: 属性用以表示显示图 ...
- Fiddler2 主菜单
Fiddler2 主菜单 六个主菜单分别是: 文件(File) Capture Traffic ——启用捕获功能,快捷键 F12 此功能的开启/关闭状态,程序安装后默认是开启的.可以在 Fiddler ...
- zookeeper的安装(图文详解。。。来点击哦!)
zookeeper的安装(图文详解...来点击哦!) 一.服务器的配置 三台服务器: 192.168.83.133 sunshine 192.168.83.134 sunshineMin 19 ...
- 手把手原生js简单轮播图
在团队带人,突然被人问到轮播图如何实现,进入前端领域有一年多了,但很久没自己写过,一直是用大牛写的插件,今天就写个简单的适合入门者学习的小教程.当然,轮播图的实现原理与设计模式有很多种,我这里讲的是用 ...
- eclipse Run On Server 异常:could not load the Tomcat Server configuration at Servers\tomcat V5.0 Sertomcat
eclipse Run On Server 异常:could not load the Tomcat Server configuration at Servers\tomcat V5.0 Serto ...
- Python实例4
4.输入某年某月某日,判断这一天是这一年的第几天? 正解: 源码:
- SVN-Server搭建及配置
SVN是Subversion的简称,是一个开放源代码的版本控制系统,相较于RCS.CVS,它采用了分支管理系统,它的设计目标就是取代CVS.互联网上很多版本控制服务已从CVS迁移到Subversion ...
- Linux运维人员如何学习python编程
Linux运维人员如何学习python编程 从不会写代码,到自己独立能写代码解决问题 .这个问题很重要!盲目学习所谓的项目,最后 还是不会自己写代码解决问题.首先解决了独立能写代码解决问题,再通过项目 ...