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 判断多干个数乘积是否是某个数的倍数有很多方法,比较常用的是取模,但这里并不适用,因为模数不定 会发现数都比较小,所以我们可以考虑分解质因子 ...
随机推荐
- 如何安装Elasticsearch?
最近工作中要用到搜索引擎,由于目前用的搜索引擎是LeanCloud 提供的 ,不太好用,不支持范围等搜索,而且每天还收费30元,请求次数也有限制.基于这些原因,我们只好在自己的服务器上部署搜索引擎了. ...
- Word Ladder 2015年6月3日
Given two words (beginWord and endWord), and a dictionary, find the length of shortest transformatio ...
- swift学习 - collectionView
swift CollectionView学习 效果图: 源码: ContModel.swift import UIKit class ContModel: NSObject { var title:S ...
- 12款Linux系统恢复工具
电脑死机,硬盘崩溃,花巨大的money搞个急救保护器……这都是计算机的阴暗面.时间一直这样走着,走着,不定哪天背点儿.对于电脑损坏造成的损失,着急抓狂毫无意义.相反,使用恰当的工具反而会最小化损失.你 ...
- VR全景智慧城市-提前进入商家观景,涵盖实体行业
互联网发展的迅猛势头,让很多的实体商家翻了个大跟头,更有言说,未来的大街小巷根本见不到逛街的人,可是线上商城相继曝出的假货谁来买单?相比之下眼见为实更让消费者心里觉得踏实.所以,全景智慧城市更能满足大 ...
- 一天搞定CSS:支持IE的Layout布局--16
1.BFC和Layout区别: BFC和Layout的作用是一样的,只是对浏览器的支持不同而已. BFC- -标准浏览器所具有的 Layout- -IE浏览器所具有的 BFC详解地址:http://b ...
- 如何实现windows命令提示符的tab补全
1:使用win+r打开 运行 控制台 2:输入 regedit 打开注册表 3:进入HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Command Processor\Co ...
- css样式,边界和边框,格式和布局
1.大小:width:宽:heigh:高 2.背景:1)background-color:背景颜色 2)background-image:背景图片url路径 3)background-repeat:图 ...
- Blend在WPF开发过程中的作用
WPF开发时,用VS2012就足够了,因为里面的确有控件拖放编辑和便利的带输入自动完成的xaml编辑器. 但是在需要改变某些控件的样式时,特别是style和template是,看网上搜到的教程,洋洋洒 ...
- python os模块学习
一.os模块概述 Python os模块包含普遍的操作系统功能.如果你希望你的程序能够与平台无关的话,这个模块是尤为重要的. 二.常用方法 1.os.name 输出字符串指示正在使用的平台.如果是wi ...