水题
文章平均质量分 64
everlasting__
'-'
展开
-
bzoj 2019: [Usaco2009 Nov]找工作 最长路
→题目链接←显然就是找一个最长路两个城市有路径就建一个权值为d的边如果有航线就建一个权值为d-z的边边的权值表示经过这个边可以获得多少钱最后从起点开始跑最长路就好,答案对于每个点取max有正环就是无解,跟判负环一样代码:#include #include #include #include #include #include #原创 2017-08-16 15:44:00 · 289 阅读 · 0 评论 -
bzoj 1615: [Usaco2008 Mar]The Loathesome Hay Baler麻烦的干草打包机
→题目链接←一个水题....找到从起点到终点的路径,然后算出所有的转速,最后加起来因为一个齿轮不可能被两个齿轮驱动,所以从起点到终点一定只有一条路径所以从起点开始,进行深搜就好,整个图像是一个树一样存一下每个点的父亲节点,最后从终点向上一直找就是那条路经注意:1、转速进行运算时一定要用小数,有进位什么的2、输出答案时不能直接printf("%0.lf",ans),这原创 2017-08-14 16:18:19 · 322 阅读 · 0 评论 -
bzoj 1641: [Usaco2007 Nov]Cow Hurdles 奶牛跨栏 floyd
→题目链接←我简直太弱了floyd都不会写了orz神奇的算法代码:#include#include#define inf 9999999using namespace std;int n,m,T;int Min[330][330];int main(){ scanf("%d%d%d",&n,&m,&T); for(int i=1; i<=n; i原创 2017-08-10 14:50:40 · 266 阅读 · 0 评论 -
bzoj 2015: [Usaco2010 Feb]Chocolate Giving
→题目链接←从编号为1的点跑spfa,然后把两个点到1的距离加一起就好了大水题#include#include#include#includeusing namespace std;struct node{ int to,len; int now;};vectorv[50050];int n,m,b;bool vis[50050]={false};int原创 2017-07-22 16:32:56 · 343 阅读 · 0 评论 -
bzoj 3299: [USACO2011 Open]Corn Maze玉米迷宫 最短路
→题目链接←愚蠢的我犯了一个愚蠢的错误删了一个字符后就A了...一个非常水的最短路,每个点只能访问到一次,再次访问肯定不优所以从起点跑就好了,碰到传送点传送一下就行,只要走到了终点就是答案乱七八糟的代码:#include#include#include#include#includeusing namespace std;struct nod原创 2017-08-06 16:49:40 · 587 阅读 · 0 评论 -
bzoj 3408: [Usaco2009 Oct]Heat Wave 热浪 最短路
→题目链接←一个裸的最短路,很水的数据貌似怎么跑都行我用的SPFA...很弱的代码:#include#include#include#includeusing namespace std;struct point{ int to,len;};struct node{ int now,len;};int Min[2550];int n,m,s,原创 2017-08-07 15:53:24 · 378 阅读 · 0 评论 -
bzoj 2292: 【POJ Challenge 】永远挑战 SPFA
→题目链接←我居然没有一发A掉这个水题,真是差劲犯了一个极其愚蠢的错误重写了一遍就A了然而我旁边某t姓同学告诉我说这道题djkstra然而我并不能分清djkstra和spfa的区别orzA掉了就好一个裸的最短路,貌似用什么方法都能过。代码:#include#include#include#includeusing namespace s原创 2017-08-14 08:25:27 · 304 阅读 · 0 评论 -
bzoj 1614: [Usaco2007 Jan]Telephone Lines架设电话线 二分+最短路
→题目链接←二分ans,小于等于ans的边的距离看作0,大于ans的看作1每次跑一下最短路,dis[n]代表有多少边是需要免费的所以如果dis[n]别忘了输出-1代码:#include#include#include#includeusing namespace std;struct node{ int to,len; int now;};v原创 2017-08-14 14:24:36 · 347 阅读 · 0 评论 -
bzoj 3403: [Usaco2009 Open]Cow Line 直线上的牛 暴力
→题目链接←非常非常的水为了方便+奇懒无比而用了deque真的非常的方便代码:#include#includeusing namespace std;dequev;int n;char c;int x,num=1;int main(){ scanf("%d\n",&n); for(int i=1; i<=n; i++){ c=getchar(原创 2017-08-07 19:55:14 · 293 阅读 · 0 评论 -
bzoj 3018: [Usaco2012 Nov]Distant Pastures
跑n*n遍的spfa每次最后取个max就好#include#include#include#includeusing namespace std;struct node{ int x,y; long long len;};int tox[4]={-1,0,1,0};int toy[4]={0,1,0,-1};int n,A,B;bool a[33][33];原创 2017-07-25 16:08:46 · 286 阅读 · 0 评论 -
bzoj 1218: [HNOI2003]激光炸弹 暴力
→题目链接←val[i][j]表示0~第i行,0~第j列所有炸弹价值的和然后我们暴力枚举所有的正方形左上角那个点(我是认为左上角为0,0 右下角为5000,5000)每个正方形的价值可以O(1)算出简单来说就是二位前缀和没啦~~代码:#include #include #include #include #include原创 2017-08-18 08:08:49 · 276 阅读 · 0 评论 -
bzoj 2748: [HAOI2012]音量调节 dp
→题目链接←很水的一道题如果第i首歌时音量为j是可行的,那么dp[i][j]=true最初dp[0][beginLevel]=true;之后每次暴力扫上一次的状态,转移就好代码:#include#include#include#include#include#include #define ll long long#define inf 10原创 2017-08-18 13:48:12 · 238 阅读 · 0 评论 -
bzoj 4397: [Usaco2015 dec]Breed Counting 前缀和/线段树
→题目链接←这个题我傻逼了看到区间查询我下意识地打了线段树然后一发A了后发现其他人的代码都好快啊找题解发现都是用的前缀和靠!然后又搞了一发前缀和我把两个代码都放上来吧前缀和:#include#includeusing namespace std;int n,m;int sum1[100010],sum2[100010],sum原创 2017-08-28 09:18:18 · 426 阅读 · 0 评论 -
bzoj 3401: [Usaco2009 Mar]Look Up 仰望
→题目链接←以高度为第一关键字,从大到小以序号为第二关键字,从小到大排序然后从头开始扫,每次找到后继就是第一个高于他的,然后把他的编号插到set里代码:#include#include#include#includeusing namespace std;struct node{ int x,num; friend bool operato原创 2017-09-13 14:47:14 · 271 阅读 · 0 评论 -
bzoj 3889: [Usaco2015 Jan]Cow Routing SPFA
→题目链接←双键值最短路,SPFA代码:#include#include#include#include#define ll long long#define inf 0X3f3f3f3f3f3f3f3fllusing namespace std;struct node{ int to,len1,len2;};int s,e,m,n=0;v原创 2017-09-05 11:03:35 · 250 阅读 · 0 评论 -
bzoj 3358: [Usaco2004 Jan]洪水
→题目链接←保存每个高度有多少个如果目前剩的水的体积大于目前最矮的高度的数量,那么会使水面高度整体上升1,然后把目前的高度+1然后再判断下以前是否已经有了+1后的高度,如果有把这两堆合并,再推进优先队列直到最终高度后,只要初始高度小于等于最终高度,都加进ans最后输出 最终高度 和 ans代码:#include#include#include#in原创 2017-08-22 16:25:59 · 341 阅读 · 0 评论 -
bzoj 1624: [Usaco2008 Open] Clear And Present Danger 寻宝之路 SPFA
→题目链接←裸最短路代码:#include#include#include#include#include #define inf 90000000 using namespace std; int n,m;int a[110][110];int Min[110][110];int to[10010];queueq; int ma原创 2017-08-18 16:50:42 · 233 阅读 · 0 评论 -
bzoj 1709: [Usaco2007 Oct]Super Paintball超级弹珠
→题目链接←显然的是如果对于每个点都判断一次是否能打到所有的敌人是会TLE的所以我们可以换一种想法我们维护一个点可以打到多少敌人然后对于每个敌人,我们令所有能打到他的地方的值+1所以最后只要那个地方的值>=m,就一定是可行点代码:#include#include#include#includeusing namespace std;int原创 2017-09-04 09:20:51 · 250 阅读 · 0 评论 -
bzoj 3397: [Usaco2009 Feb]Surround the Islands 环岛篱笆
→题目链接←令人一看样例就不想做的题...题面说的很麻烦..但是仔细想一想就是问一个点到其它点距离的和的最小值用并查集将岛屿处理出来将每个岛屿看作一个点然后一边输入就能一边处理出岛屿间的距离最后暴力求和取min就好代码:#include#include#define inf 233333333using namespace std;in原创 2017-09-04 09:11:49 · 378 阅读 · 0 评论 -
bzoj 3396: [Usaco2009 Jan]Total flow 水流 网络流
→题目链接←看到题面后感觉可能有什么奇技淫巧...?但是懒得想数据辣么小直接网络流搞一搞就行了代码:#include#include#include#include#include #define ll long long#define inf 10000001 using namespace std; struct node{原创 2017-09-04 08:24:22 · 249 阅读 · 0 评论 -
bzoj 3412: [Usaco2009 Dec]Music Notes乐谱
→题目链接←维护前缀和,对于每次询问找到第一个大于它的数(也就是upper_bound)的下标,就是答案手写可以二分找用stl可以用upper_bound代码:#include#include#includeusing namespace std;int n,m;int sum[50050];int main(){ scanf("%d%d",原创 2017-08-25 14:15:54 · 415 阅读 · 0 评论 -
bzoj 1607: [Usaco2008 Dec]Patting Heads 轻拍牛头
→题目链接←纯暴力搞显然是过不了的我们记录下每个数的数量,然后算出这个数对其他的数的贡献最后输出时要减一,因为它算贡献时是算了自己的代码:#include#include#include#include#define inf 999999999#define ll long longusing namespace std;int n;int num原创 2017-08-15 09:23:19 · 290 阅读 · 0 评论 -
BZOJ1651--[Usaco2006 Feb]Stall Reservations 专用牛棚
1651: [Usaco2006 Feb]Stall Reservations 专用牛棚Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 849 Solved: 484[Submit][Status][Discuss]DescriptionOh those picky N (1 <= N <= 50,000) cows! T原创 2017-01-17 14:15:46 · 1015 阅读 · 0 评论 -
bzoj 4096: [Usaco2013 dec]Milk Scheduling 贪心
→题目链接←从后往前扫deadline,每次找到一个符合条件并且贡献最大的,就算进答案代码:#include#include#include#include#include#includeusing namespace std;struct node{ int g,d; friend bool operator < (node a,node b){ i原创 2017-08-14 11:46:13 · 414 阅读 · 0 评论 -
bzoj 3016: [Usaco2012 Nov]Clumsy Cows 栈
→题目链接←说是栈,其实就用一个变量记录下就好,我用的sum碰到(就++,碰到)就--当sum为负时一定是不合法的,这时候一定要改一下,所以ans++然后令sum等于1,因为把一个不合法的)改成了(最后如果sum大于0,就说明还要改sum/2次所以最后ans=ans+sum/2代码:#include#include#include#includ原创 2017-08-14 09:24:10 · 379 阅读 · 0 评论 -
bzoj 1649: [Usaco2006 Dec]Cow Roller Coaster 背包dp
→题目链接←dp[i][j]表示铁轨长度为i,花费为j时有趣指数最大值代码:#include#include#include#include#include#include#define inf 999999999#define ll long longusing namespace std;struct node{ int s,e,w,c;}a[1原创 2017-08-15 10:06:49 · 258 阅读 · 0 评论 -
bzoj 1731: [Usaco2005 dec]Layout 排队布局 差分约束
→题目链接←裸的差分约束对于两个有好感的牛,addedge(i,j,len);对于两个反感的牛,addedge(j,i,-len);最后还要addedge(i,i-1,0);之后跑最短路就行代码:#include#include#include#include#include#include#define inf 999999999using原创 2017-08-16 10:04:25 · 286 阅读 · 0 评论 -
bzoj 3310: [Usaco2013 Nov]Empty Stalls
→题目链接←看那个著名的“USACO被虐记”说的是按照题意搞一搞就好了但是无比之弱的我还是T了两发按照题意暴力搞什么的都是骗人的qwq不能每次都暴力处理没个牛先把所有的牛都安放在他喜欢的位置上然后从头到尾最多扫两边就好了因为保证牛的数量至多为n-1每次把多的牛往♂后♂搞一个很弱的代码:#include#includeusing name原创 2017-08-04 22:15:50 · 455 阅读 · 0 评论