自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+

LIN452

努力努力再努力 Since 150713

原创 BZOJ1539/POI2005 Double-row

由于数据保证有一组方案达到目标,那么相同高度的士兵个数不超过2. 每列交换的次数最多是1,多次交换是无意义的. 那么假如身高相同的两个士兵在同一行中,它们所在的列数a,b中一定有一列要进行交换,且只有一列. 那么假如身高相同的两个士兵在不同行中,它们所在的列数a,b中要么都进行...

2016-10-27 07:20:39 435 0

原创 BZOJ1537/POI2005 The Bus

假设dp[i][j]表示在(i,j)位置能够接到的最多乘客数量,我们会发现很多的状态是无效的,因此只要记录到达站点的状态.由于只能向北或向东走,只可能通过西南的站点到达(i,j),也就是所有满足a<=i&&b<=j的站点(a,b).这样就有两维状态,可以通过排序+区间求...

2016-10-27 07:18:18 338 0

原创 BZOJ1534/POI2005 Fibonacci sums

首先把两个序列相加得到初始序列.之后就对初始序列进行调整: 对于f[i]>=2的情况可以根据2*f[i]=f[i]+f[i-1]+f[i-2]=f[i+1]+f[i-2]转化为f[i-2]++,f[i+1]++. 对于f[i]=1&&f[i+1]=1,根据f[i+2]=f...

2016-10-27 07:16:21 390 0

原创 BZOJ153/POI2005 A Journey to Mars

确定了起点和方向之后,旅行的过程就确定了,到达i点的花费<=到i点之间的油料数量就是题目的限制条件. 由于是绕圈问题,我们可以把序列复制相接,转化成序列上的问题. 设sum[j]sum[j] 表示到jj之前所得油料数量dis[j]dis[j]表示1到jj的距离,对于起点i...

2016-10-27 07:14:55 426 0

原创 BZOJ1532/POI2005 Dicing

直接求似乎不简单,由于题目求”最大值最小问题”,可以转化为二分答案来验证一个解是否成立.假设枚举的答案是x,那么所有人赢得的场次都<=x.而每场比赛最多只有一个人获胜,我们可以根据此信息,构图: 设置源点与每个人建边,每个人与它所参加的每场比赛建边,每场比赛与超级汇点建边并且流量设置为1....

2016-10-27 07:13:09 304 0

原创 BZOJ1531/POI2005 Bank notes

裸的多重背包,利用二进制进行优化: 假设有12枚面额为3的硬币,可以把它转化为 面值为3,6,12,15的硬币分别1枚.这样就把物品总数减少到log件.#include<cstdio> #include<cstring> #include<algo...

2016-10-27 07:10:45 467 0

原创 BZOJ1529/POI2005 Piggy banks

根据图中的信息,可以构造出一棵基环外向树.每个节点指向存放自己钥匙的节点.对于每一个连通块,其中必定会出现一个环,只要将环上任意一个存钱罐打破,那么这整个联通块中的所有存钱罐都能打开了. 因此答案就是构图后联通块的个数.#include<cstdio> #include<cst...

2016-10-27 07:07:43 286 0

原创 BOZJ1528/POI 2005Toy Cars

假设地板上能放足够多的玩具,那么肯定一次性将所有玩具都拿下来.可是题目中有了k这个限制.为了完成题目的要求,不得不将某些玩具拿回去,使得新玩具有地方放置.那么问题就是将什么玩具拿回去.如果某个玩具x之后不再出现,那么一定将它拿走,既不会对答案产生影响,又有利于以后的玩具放置.万一没有不再用的玩具了...

2016-10-27 07:06:29 420 0

原创 BZOJ1527/POI 2005 Point

相似点集有一个性质,重心在点集中的位置是相同的,可以通过点集的重心判断现点集是否能还原成原点集. 如果两个点集的点数不同,肯定是不相似的. 移动:直接根据重心的位置,确定现点集的移动方式,使得两个点集的重心重合. 缩放:根据两个点集内的点到重心的最短距离确定缩放比例,注意如果最短距离是0...

2016-10-27 07:04:27 240 0

原创 BZOJ1526/POI 2005 Bankomat

所有可能的输入方案一共有10000种,我们可以对每一个进行检验.对每个录像求出对应的f[i][k]表示第i个字符以后第一个字符k的位置,预处理出f数组之后就可以对每个数字进行O(1)检验了. 由于无法同时求出每个串的f数组,因此可以对每个串检验10000种可能,已经不可能的数字之后就不必...

2016-10-27 07:00:37 381 0

原创 BZOJ2801/POI2012 Minimalist Security

Task 给出一个N个顶点、M条边的无向图,边(u,v)有权值w(u,v),顶点i也有权值p(i), 并且对于每条边(u,v)都满足p(u)+p(v)>=w(u,v)。 现在要将顶点i的权值减去z(i),其中0<=z(i)<=p(i)。 修改后设顶点i的权值p’(...

2016-10-18 07:32:12 348 0

原创 BZOJ2802/POI 2012 Warehouse Store

Task 有一家专卖一种商品的店,考虑连续的n天。 第i天上午会进货Ai件商品,中午的时候会有顾客需要购买Bi件商品,可以选择满足顾客的要求,或是无视掉他。 如果要满足顾客的需求,就必须要有足够的库存。问最多能够满足多少个顾客的需求。 n<=250,000,0<...

2016-10-17 17:50:15 244 0

原创 BZOJ2800/POI2012 Leveling Ground

Task 给出n个整数X_1,X_2,…X_n,再给出两个正整数a、b,可以进行下面四种操作: 1. 选择正整数l,r (1<=l<=r<=n),将X_l,X_{l+1},…,X_r都加上a。 2. 选择正整数l,r (1<=l<=r<=n),将X_l,X...

2016-10-09 22:24:42 661 0

原创 BZOJ2799/POI2012 Salaries

Task 给出一棵n个结点的有根树,结点用正整数1~n编号。 每个结点有一个1~n的正整数权值,不同结点的权值不相同, 并且一个结点的权值一定比它父结点的权值大(根结点的权值最大,一定是n)。现在有些结点的权值是已知的,并且如果一个结点的权值已知,它父结点的权值也一定已知。 问还有...

2016-10-09 21:29:30 465 0

原创 BZOJ2798/POI 2012 Bidding

Task A和B两个人在玩一个游戏,这个游戏是他们轮流操作一对整数(x,y)。 初始时(x,y)=(1,0),可以进行三种操作: 1. 将(x,y)变成(1,x+y)。 2. 将(x,y)变成(2x,y)。 3. 将(x,y)变成(3x,y)。 给定正整数n (n<=30...

2016-10-09 21:05:45 688 0

原创 BZOJ2798/POI2012 Squarks

Task 设有n个互不相同的正整数{X1,X2,…Xn},任取两个Xi,Xj(i≠j),能算出Xi+Xj。现在所有取法共n*(n-1)/2个和,要你求出X1,X2,…Xn。 3<=n<=300, 每个正整数不超过10^8Solution 假设原序列是单调递增的,f...

2016-10-09 20:51:54 360 0

原创 BZOJ2796/POI2012 Fibonacci Representation

Task Fib数列0,1,1,2,3,5,8,13,21。 给出一个数字,用FIB数列各项加加减减来得到。例如 10=5+5 19=21-2 求出通过加减得到K的最少项数. 1<=K<=10^17.Solution 有一个贪心的思路,每次找到离K最近的两...

2016-10-09 20:22:17 327 0

原创 BZOJ2795/POI2012 A horrible poem

Task 给出一个由小写英文字母组成的字符串S,再给出q个询问,要求回答S某个子串的最短循环节。 如果字符串B是字符串A的循环节,那么A可以由B重复若干次得到。 n<=500,000, q<=2,000,000.Solution 假如最短循环节为lenlen,设t=n...

2016-10-09 19:44:35 386 0

原创 HDU5808(Bestcoder Round86)Price List Strike Back

题目戳这假如我们已知第i天可以购买的所有商品,那么剩下就是01背包的问题了.能够购买的所有商品由两个条件决定:编号下标和距离.我们可以减少一个维度使问题更简单.假如把询问和点一起按照距离d排序,那么就能保证询问到i时,所有考虑到的点x一定满足dis[x]<=didis[x]<=di这一...

2016-10-09 18:49:22 642 0

原创 BZOJ2794/POI2012 Cloakroom

Task 有n件物品,每件物品有三个属性a[i], b[i], c[i] .(a[i]<b[i]) 再给出q个询问,每个询问由非负整数m, k, s组成,问是否能够选出某些物品使得: 1. 对于每个选的物品i,满足a[i]<=m且b[i]>m+s。 2. 所有选出物品的c[i]...

2016-10-08 22:41:47 410 0

原创 BZOJ2793/POI2012 Vouchers

Task考虑正整数集合,现在有n组人依次来取数,假设第i组来了x人,他们每个取的数一定是x的倍数,并且是还剩下的最小的x个。 正整数中有m个数被标成了幸运数,问有哪些人取到了幸运数。m<=1,000,000, n<=1,000,000, x<=1,000,000.Solutio...

2016-10-08 22:02:27 225 0

原创 BZOJ3060/POI 2012 Tour de Byteotia

Task   给定一个n个点m条边的无向图,问最少删掉多少条边能使得编号小于等于k的点都不在环上。   1 ≤ n ≤ 1,000,000,1 ≤ m ≤ 2,000,000,1 ≤ k ≤ n。 Solution  对于删边不容易解决的情况,可以”正难则反”,考虑是否能求出最多能加的边.对...

2016-10-08 19:53:24 314 0

原创 BZOJ2792/POI2012 Well

Task 给出n个正整数X1,X2,…Xn,可以进行不超过m次操作,每次操作选择一个非零的Xi,并将它减一。 最终要求存在某个k满足Xk=0,并且z=max{|Xi - Xi+1|}最小。输出最小的z和此时最小的k。 1<=n<=1,000,000, 1<=m<=10...

2016-10-08 18:43:42 353 0

原创 BZOJ2791/POI2012 Rendezvous

Task 给定一个n个顶点的有向图,每个顶点有且仅有一条出边。 对于顶点i,记它的出边为(i, a[i])。再给出q组询问,每组询问由两个顶点a、b组成,要求输出满足下面条件的x、y: 1. 从顶点a沿着出边走x步和从顶点b沿着出边走y步后到达的顶点相同。 2. 在满足条件1的情况...

2016-10-08 16:26:11 451 0

原创 BZOj2790/POI2012 Distance

Task 对于两个正整数a、b,这样定义函数d(a,b):每次操作可以选择一个质数p,将a变成a*p或a/p, 如果选择变成a/p就要保证p是a的约数,d(a,b)表示将a变成b所需的最少操作次数。例如d(69,42)=3。 现在给出n个正整数A1,A2,…,An,对于每个i (1<=...

2016-10-08 15:59:12 356 0

原创 BZOJ2788/POI2012 Festival

Task 有n个正整数X1,X2,…,Xn,再给出m1+m2个限制条件,限制分为两类: 1. 给出a,b (1<=a,b<=n),要求满足Xa + 1 = Xb 2. 给出c,d (1<=c,d<=n),要求满足Xc <= Xd 在满足所有限制的条件下,求集合...

2016-10-08 15:12:07 469 0

原创 IOI2011 race

Task: 给定一棵带权树,求出边数最小的一条路径使得路径长度为K. 1 ≤ N ≤ 200000 ,1 ≤ K ≤ 1000000Solution: 枚举路径的lca为节点x,只考虑一定经过x的路径. 再枚举其中的一个端点y,设y到x的距离为d1,确定了y,我们就知道了路...

2016-10-08 14:13:13 351 0

原创 IOI2011 ricehub

Task: n块稻田,每块稻田一个位置pi,稻田位置可能重叠.现在可以设置一个米仓,一块稻田运送粮食的代价就是运送的距离,现在给出花费t,求出在t内最多能运送多少粮食. n≤1e5,pi≤1e9,t≤2e15.Solution: 假如米仓的位置确定,可以确定最后选中的...

2016-10-08 14:06:17 855 0

原创 USACO2011Open Gold Balanced Cow Subsets

N的范围很小,可以联想到枚举子集和状压.但是如果直接枚举两个子集,显然是不够的.那么我们可以联想到折半枚举!Meet inthe Middle!     把n个数分成两部分A,B集合,答案子集的来源有以下几种: 1.    A集合的子集. 2.   B集合的子集. 3.   一部分是A的子集,一部...

2016-06-28 17:52:41 811 0

原创 USACO2011Open Gold Bookshelf 题解

可以把题目理解为在n本书中”切几刀”.      当n2)可以解决:      dp[i]表示在前i本书,第i本书为当前书架的最后一本书的最小高度.dp[i]=min{dp[j]+mx[j+1,i]}且sum[j+1,i]        当n 通过dp[i]=min{dp[j]+mx[j...

2016-06-28 17:48:19 654 0

原创 USACO2011Open Silver Unlocking Blocks 题解

搜索搜索搜索!      每次把一块积木移动一步,而且每块积木内部的相对位置是不变的,那么每次只要记录积木任意一点的位置表示状态即可.为了方便,我们可以设为每个积木包围块的左上角的点.      如何实现? 一种想法是暴搜!可惜T了… 暴搜优化一下来个迭代加深,每次设定一个步数,可惜还是T了. 由...

2016-06-28 17:16:59 506 0

原创 USACO2011Open Silver Running Laps题解

//请忽略我把牛看作羊.... 由题意,我们可以得到 t*vi-t*vj=kC.那么i,j相遇的次数就是最大的k(整数).为了得到最大的k就要使t最大,而tmax=L*C/vmax. 那么 把式子整理得到:      k=L*(vi-vj)/vmax.(向下取整)      对于第i只,它...

2016-06-28 17:07:58 523 0

原创 USACO2011Open Bronze 3lines 题解

[思路] 符合 FJ 的要求有两种情况: 三条直线平行或者两条直线平行并与一条直线垂直.至于横竖的 问题,可以通过反转奶牛的坐标转化成相同的方式. 三条平行直线: 把所有点的横坐标记录下来,如果不同的横坐标个数小于等于 3,那么 符合条件. 两条平行与一条直线垂直: 把所有的纵坐标和它们个数记下,...

2016-06-28 17:01:22 724 0

原创 CodeForces 160D Edges in MST 题解

[题意]       给出一个n个点m条边的无向连通图,判断图中每条边是否一定在最小生成树上.      n,m [思路] 由于最小生成树的性质,我们造出任意一棵最小生成树,并记录下与最小生成树权值相等的所有边. 暴力版: 沿着非树边x的两个端点走到它们的lca,在环上去找与x权值相同的边,如果...

2016-06-28 07:13:04 469 0

原创 CodeForces 444C DZY Loves Colors题解

[题意]      有n个气球,每个气球有一个颜色x,改变为y后,美丽值增加|x-y|.      对一个序列有两种操作: 1.    把区间在[L,R]的颜色染成x. 2.   询问区间[L,R]的气球的美丽值总和. n [思路]      区间更新,区间询问可以联想到线段树.      只是更...

2016-06-27 22:40:45 590 0

原创 CodeForces 444B DZY Loves FFT 题解

[题意]      给出一个的1~n的排列A,和一个长度为n,只有0,1的序列B,求序列C: Ci=max(aj,bi-j)(i      数据保证是随机构造的. [思路] 这题坑啊.不怕难题,就怕水题ToT      因为数据是随机的,所以可以乱搞(什么鬼啊).      //...

2016-06-27 22:33:07 580 0

转载 dfs序的常见用法整理

dfs序就是一棵树在dfs遍历时组成的节点序列. 它有这样一个特点:一棵子树的dfs序是一个区间. 下面是dfs序的基本代码: void dfs(int x,int pre,int d){//L,R表示一个子树的范围 L[x]=++tot; dep[x]=d; for(in...

2016-06-27 21:32:06 3877 0

原创 毯子 题解(COCI 2008-2009Final C)

[题意] N 块矩形毯子铺在地上。0秒时(0,0)处有一桶油倒了,然后开始流呀流,每秒往八个方向扩散一个单位。注意,这里的坐标描述一个单元格,不表示点。M个询问,每次问一个时间点被油染到的毯子面积(若有毯子重叠,面积也要累加,如一个单位格被三个毯子覆盖,那么被油染到之后就算3个单位面积)。 [思路...

2016-06-26 15:53:13 556 0

原创 维修道路 题解

[题意] 一棵n个节点的树,求两条路径s1,s2最大的长度积,满足s1,s2都是两点之间的最短路径,而且两条路径不含任何公共点. n [思路]      O(n^2):          枚举树上的每条边,把此边从树上移除,那么原来的树就变成了两棵子树:所求的两条路径分别在两棵子树中.那么为了满...

2016-06-26 15:45:20 352 0

原创 Since150713的HelloWorld!!!

听说第一篇文章都很重要... 但我认为...此处无声胜有声...

2016-06-26 15:35:20 344 1

提示
确定要删除当前文章?
取消 删除