usaco 2002 月赛 Chores 题解
Description
Farmer John has a list of N (3 <= N <= 10,000) chores that must be completed. Each chore requires an integer time (1 <= length of time <= 100) to complete and there may be other chores that must be completed before this chore is started. We will call these
prerequisite chores. At least one chore has no prerequisite: the very first one, number 1. Farmer John's list of chores is nicely ordered, and chore K (K > 1) can have only chores 1,.K-1 as prerequisites. Write a program that reads a list of chores from 1
to N with associated times and all perquisite chores. Now calculate the shortest time it will take to complete all N chores. Of course, chores that do not depend on each other can be performed simultaneously.
Input
* Lines 2..N+1: N lines, each with several space-separated integers. Line 2 contains chore 1; line 3 contains chore 2, and so on. Each line contains the length of time to complete the chore, the number of the prerequisites, Pi, (0 <= Pi <= 100), and the Pi
prerequisites (range 1..N, of course).
Output
#include<stdio.h> #include<cstring> using namespace std; const long maxn=10001;const long INF=1; bool flag[maxn];long cnt,i,n,j,xx,time,y,h,t,go,now,ans,tong; long dis[maxn],begin[maxn],end[maxn],x[200*maxn]; struct arr{long l,r,s,next;}a[200*maxn]; void make_up(long l,long r,long v) { a[++cnt].l=l;a[cnt].r=r;a[cnt].s=-v;a[cnt].next=-1; if (begin[l]==0) {begin[l]=cnt;end[l]=cnt;} else {a[end[l]].next=cnt;end[l]=cnt;} } int main() { //freopen("chores.in","r",stdin);freopen("chores.out","w",stdout); scanf("%ld",&n); for (i=1;i<=n;i++) { scanf("%ld",&time); scanf("%ld",&xx); for (j=1;j<=xx;j++) { scanf("%ld",&y); make_up(y,i,time); } if (xx==0) make_up(0,i,time); } memset(flag,0,sizeof(flag));memset(dis,INF,sizeof(dis)); h=0;t=1;x[1]=0;dis[0]=0;flag[0]=true; while (h<t) { now=x[++h];if (begin[now]==0) continue;i=begin[now]; while (true) { go=a[i].r; if (dis[now]+a[i].s<dis[go]) { dis[go]=dis[now]+a[i].s; if (!flag[go]) { flag[go]=true; x[++t]=go; } } if (a[i].next==-1) break;i=a[i].next; } flag[now]=false; } for (i=1;i<=n;i++) if (-dis[i]>ans) ans=-dis[i]; printf("%ld",ans); //scanf("%ld",&n); return 0; }
然而交了之后一直TLE,自己下了个数据,发现最后一个点大概要13s左右!想不到在稠密图里,SPFA的效率又如此之低!(边表的常数又很大)无论怎么优化都不行!
#include<stdio.h> #include<cstring> using namespace std; long f[10001],n,i,j,max,ans,xx,y; int main() { //freopen("chores.in","r",stdin);freopen("chores.out","w",stdout); scanf("%ld",&n); for (i=1;i<=n;i++) { scanf("%ld",&f[i]); scanf("%ld",&xx);max=0; for (j=1;j<=xx;j++) { scanf("%ld",&y); if (f[y]>max) max=f[y]; } f[i]+=max; if (f[i]>ans) ans=f[i]; } printf("%ld",ans); //scanf("%ld",&n); return 0; }
然而仔细一想,我发现他们只是钻了一个数据的漏洞——刚好数据的前后关系是由小到大的。思考了很长时间,我研究出了一个更加高级的算法——记忆化深搜+边表优化!
#include<stdio.h> #include<cstring> using namespace std; const long maxn=10001;const long INF=1; long time[maxn],dp[maxn],begin[maxn],end[maxn],cnt,j,n,i,x,y,ans; struct arr{long l,r,next;}a[200*maxn]; void make_up(long l,long r) { a[++cnt].l=l;a[cnt].r=r;a[cnt].next=-1; if (begin[l]==0) {begin[l]=cnt;end[l]=cnt;} else {a[end[l]].next=cnt;end[l]=cnt;} } long go(long k) { if (dp[k]>0) return dp[k]; long now=begin[k]; while (now>0) { long temp=go(a[now].r); dp[k]=(temp>dp[k])?temp:dp[k]; now=a[now].next; } dp[k]+=time[k]; return dp[k]; } int main() { //freopen("chores.in","r",stdin);freopen("chores.out","w",stdout); scanf("%ld",&n); for (i=1;i<=n;i++) { scanf("%ld",&time[i]); scanf("%ld",&x); for (j=1;j<=x;j++) { scanf("%ld",&y);make_up(i,y); } if (x==0) dp[i]=time[i]; } for (i=1;i<=n;i++) { long temp=go(i); ans=(temp>ans)?temp:ans; } printf("%ld",ans); //scanf("%ld",&n); return 0; }
希望众神牛看到后能够留言指导!
usaco 2002 月赛 Chores 题解的更多相关文章
- usaco 2002 月赛 Fiber Communications 题解
Description Farmer John wants to connect his N (1 <= N <= 1,000) barns (numbered 1..N) with a ...
- POJ1944 Fiber Communications (USACO 2002 February)
Fiber Communications 总时间限制: 1000ms 内存限制: 65536kB 描述 Farmer John wants to connect his N (1 <= N ...
- csu-2018年11月月赛Round2-div1题解
csu-2018年11月月赛Round2-div1题解 A(2191):Wells的积木游戏 Description Wells有一堆N个积木,标号1~N,每个标号只出现一次 由于Wells是手残党, ...
- csu-2018年11月月赛Round2-div2题解
csu-2018年11月月赛Round2-div2题解 A(2193):昆虫繁殖 Description 科学家在热带森林中发现了一种特殊的昆虫,这种昆虫的繁殖能力很强.每对成虫过x个月产y对卵,每对 ...
- usaco 2008 月赛 lites 开关灯 题解
题目: Farmer John尝试通过和奶牛们玩益智玩具来保持他的奶牛们思维敏捷. 其中一个大型玩具是 牛栏中的灯. N (2 <= N <= 100,000) 头奶牛中的每一 ...
- USACO全部月赛及GateWay数据
月赛: 以07年open为例,网站如下 http://contest.usaco.org/OPEN07 其他的格式是http://contest.usaco.org/月份(月份的英文前三位,比如1月是 ...
- 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&& ...
- 洛谷10月月赛II题解
[咻咻咻] (https://www.luogu.org/contestnew/show/11616) 令人窒息的洛谷月赛,即将参加NOIp的我竟然只会一道题(也可以说一道也不会),最终145的我只能 ...
- BZOJ Lydsy5月月赛 ADG题解
题目链接 BZOJ5月月赛 题解 好弱啊QAQ只写出三题 A 判断多干个数乘积是否是某个数的倍数有很多方法,比较常用的是取模,但这里并不适用,因为模数不定 会发现数都比较小,所以我们可以考虑分解质因子 ...
随机推荐
- HourRank 19
https://www.hackerrank.com/contests/hourrank-19/challenges 第一题略. 第二题是nim博弈,问删掉一个区间的石子,使得先手败的方案有几种,明显 ...
- 014 一对多关联映射 单向(one-to-many)
在对象模型中,一对多的关联关系,使用集合来表示. 实例场景:班级对学生:Classes(班级)和Student(学生)之间是一对多的关系. 多对一.一对多的区别: 多对一关联映射:在多的端加入一个外键 ...
- javaWeb学习总结(11)- 监听器(Listener)在开发中的应用
监听器在JavaWeb开发中用得比较多,下面说一下监听器(Listener)在开发中的常见应用 一.统计当前在线人数 在JavaWeb应用开发中,有时候我们需要统计当前在线的用户数,此时就可以使用监听 ...
- Js判断是否是直接进入本页面的
今天带来一个Js的小示例,用来判断当前页面的链接来路.很多人应该可以用到,这个虽然非常简单,但是用到的地方却还是挺多的 首先新建一个index.html,代码如下 <!DOCTYPE html& ...
- reshape: from long to wide format(转)
This is to continue on the topic of using the melt/cast functions in reshape to convert between long ...
- 学习python的第一个小目标:通过requests+xlrd实现简单接口测试,将测试用例维护在表格中,与脚本分开。
小白的学习方式:通过确定一个小目标来想办法实现它,再通过笔记来加深印象. 面对标题中的小目标我陷入了思考....嗯,首先实现利用xlrd库来取出想要的用例 首先用表格准备好用例,如图下: 先试下取nu ...
- centos6.5 scala环境变量
[root@m1 ~]# vi /etc/profile export SCALA_HOME=/usr/local/soft/scala-2.11.8export PATH=$PATH:$SCALA_ ...
- Linux常用命令-jdk和Tomcat
一.JDK的安装和配置 1.下载jdk文件 去官方网站下载Linux 64位 jdk-8u131-linux-x64.tar.gz 2.使用Ftp工具上传到/usr/local 下. 使用命令:ta ...
- JavaScript中return的用法详解
JavaScript中return的用法详解 最近,跟身边学前端的朋友了解,有很多人对函数中的this的用法和指向问题比较模糊,这里写一篇博客跟大家一起探讨一下this的用法和指向性问题. 1定义 t ...
- Autotest添加测试用例小结
Autotest本身是一个自动化测试框架,可以在上面添加各种测试工具用于系统测试.前几天我在上面添加了几个基于龙芯桌面5.0系统的性能测试工具.现在做以下总结,大体写以下添加的过程. 以unixben ...