题目 727 [网络流24题] 太空飞行计划
2014-04-24 18:10:45
|
|
题目 750 栅格网络流
2014-04-24 17:55:58
|
|
回复 @digital-T :
谢谢神犇,你代码中的F我猜应该是记录的天数吧,具体细节有些不太理解的地方.这道题网上用原题搜索找不到解题报告(可能是我方法有问题吧),如果神犇有时间的话不知是否可以写篇题解点拨下蒟蒻,非常感谢
题目 749 电子书狂热者
2014-04-24 17:51:31
|
|
题目 751 螺旋方阵
2014-04-24 17:27:29
|
|
|
|
VIP是不是要有spj啊????为毛最短路不行,只能最长路
|
|
VIP上面的2b不要再刷了,2不2啊
题目 1309 [HAOI 2006]受欢迎的牛
2014-04-24 16:03:41
|
|
|
|
题目 1309 [HAOI 2006]受欢迎的牛
2014-04-24 15:19:18
|
|
#include<cstdio>
#include<cstring> #include<iostream> using namespace std; struct sky { int ff,tt,next; }; sky c[50005]; int _[10005],__[10005],___[10005],____[10005],_____[10005]; int ______[50005]; bool v[50005]; int n,m,top,now,colors,ans,tot,ret; char ch; inline void add(int x,int y) { tot++; c[tot].ff=x; c[tot].tt=y; c[tot].next=______[x]; ______[x]=tot; } inline int read() { while (!isdigit(ch = getchar())); ret = ch-48; while (isdigit(ch = getchar())) (ret *= 10) += ch-48; return ret; } void tarjan(int x) { now++; _[x]=__[x]=now; ___[++top]=x; v[x]=1; for (int i=______[x];i;i=c[i].next) { if (!_[c[i].tt]) { tarjan(c[i].tt); __[x]=min(__[x],__[c[i].tt]); } else { if (v[x]) { __[x]=min(__[x],_[c[i].tt]); } } } if (__[x]==_[x]) { colors++; while (___[top+1]!=x) { ____[___[top]]=colors; _____[colors]++; v[___[top]]=0; top--; } } } int main() { freopen("cow.in","r",stdin); freopen("cow.out","w",stdout); n = read(); m = read(); memset(______,0,sizeof(______)); tot=0; for (int i=1;i<=m;i++) { int x,y; x=read();y=read(); add(x,y); } now=top=colors=0; memset(_____,0,sizeof(_____)); memset(_,0,sizeof(_)); memset(v,0,sizeof(v)); for (int i=1;i<=n;i++) { if (_[i]) continue; tarjan(i); } memset(v,1,sizeof(v)); for (int i=1;i<=tot;i++) { if (____[c[i].ff]==____[c[i].tt]) continue; v[____[c[i].ff]]=0; } ans=0; for (int i=1;i<=colors;i++) { if (v[i]) { if (ans) { printf("0"); return 0; } ans=_____[i]; } } printf("%d",ans); } |
|
这成了机房里的竞速题了- -
题目 1309 [HAOI 2006]受欢迎的牛
2014-04-24 15:04:53
|
|
VIP额,用BST秒过
|
|
解方程组....忘了变元.....逗比地调了仨小时...
题目 1371 [HAOI 2013]开关控制
2014-04-24 12:10:15
|
|
细节哟~
|
|
设f[i][j]表示前i个人抄前j本书的最小时间,S[i]表示前i本书所花费的最小时间。
那么初始状态就是f[1][i]=S[i] f[i][i]=max(f[i-1][i-1],S[i]-S[i-1]) 转移方程:f[i][j]=min(f[i-1][k],S[j]-S[k]) k∈[1,j) 最终状态:f[K][N] 由于只要输出一种解,将得到的f[K][N]贪心求出每个人的抄写时间。 |
|
这个卡时间过……
|
|
再次被读入\n给坑了
题目 942 [東方S3] 比那名居天子
2014-04-23 21:35:47
|
|
练一练pollard_rho
题目 1268 [NOIP 2012PJ]质因数分解
2014-04-23 21:08:47
|
|
排前头的竟然是Pascal,是C++中数组下标只能从0开始的原因?
|
|
题目 751 螺旋方阵
2014-04-23 19:57:35
|