NOIP2010提高组解题报告.doc

上传人:xt****7 文档编号:122845957 上传时间:2020-03-07 格式:DOC 页数:6 大小:320KB
返回 下载 相关 举报
NOIP2010提高组解题报告.doc_第1页
第1页 / 共6页
NOIP2010提高组解题报告.doc_第2页
第2页 / 共6页
NOIP2010提高组解题报告.doc_第3页
第3页 / 共6页
NOIP2010提高组解题报告.doc_第4页
第4页 / 共6页
NOIP2010提高组解题报告.doc_第5页
第5页 / 共6页
点击查看更多>>
资源描述

《NOIP2010提高组解题报告.doc》由会员分享,可在线阅读,更多相关《NOIP2010提高组解题报告.doc(6页珍藏版)》请在金锄头文库上搜索。

1、NOIP2010解题报告(提高组)Translate开一个队列进行模拟就行了。PS:这题数据比较厚道,按照题目的描述来说,单词的编号是非负整数,也就是说可以是0。但是数据中并没有0,否则就要有很多人要降10分了。Tortoise动态规划。用Fi1,i2,i3,i4表示数字1的卡片取了i1张,数字2的卡片取了i2张,数字3的卡片取了i3张,数字4的卡片取了i4张,可以取得最大的分数。写起来很好写,四个for,再加上四个if。Fi1,i2,i3,i4=max(Fi1-1,i2,i3,i4,Fi1,i2-1,i3,i4,Fi1,i2,i3-1,i4,Fi1,i2,i3,i4-1)+score1+i1

2、+i2*2+i3*3+i4*4PS:这题用120*40*40*40,350*40*40*40的算法都是可以的。Prison二分+二分图判定并查集解法1:先二分答案,然后进行二分图的判定。判定方法如下:首先取一个没有走过的结点放在了左图,然后把和这个点有边的点放在右图,然后再把和这些右图有边的点放在左图,一直下去,知道把所有点都放好,或者出现矛盾为止。解法2:把边权从大到小排一次序,依次插入。用并查集维护这些边之间有没有矛盾。详情看并查集经典例题:PKU1182食物链。Flow(floodfill动态规划各种乱搞算法)+(贪心+动态规划各种乱搞算法)最短路显然第一问一次O(NM)的floodfi

3、ll就可以求出是否可以到达全部最后一层的格子。现在假设最后一行的所有格子都可以到达。定理1:从第一行的格子,可以到达的最后一行的格子必然是连续的一段。证明1:假设格子A可以到达的最后一行中间有部分格子不可到达。由题设可知,必有另一个格子B可以到达这些A不可到达的格子。但是,显然A到达下面格子的路径必然与B到达这些A不可到达的格子的路径有重合部分,所以,A也能到达下面的A到达不了的格子。矛盾,所以假设不成立,原命题成立。定理2:第一行从左到右的格子对应下面的格子区间的左边界和右边界必然是单调不递减的。证明2:假设第一行有格子A、B,并且A在B左边,最后一行有格子C、D,并且C在D左边。假设A能到

4、达D不能到达C,B能到达C不能到达D。那么,A到D和B到C的路径必然有重合的部分,所以A也能到达C,B也能到达D。所以假设不成立,原命题成立。定理3:从任何一个格子出发,可以到达的最后一层格子也是连续。证明3:与定理1类似,略。上面3个定理,可以得出一个大概的算法:第一步:先把上面每一个格子对应的区间求出来;第二步:然后再对这些区间进行操作。第一步方法1:枚举上面一层每个格子,进行floodfill,把下面可以到达的区间求出来。然后对于第一层每个格子,它需要枚举当且仅当它左边和右边的格子都不能到达它。第一步方法2:从flx,y表示(x,y)能到达区间的左边界,用frx,y表示(x,y)能到达区

5、间的右边界。flx,y:=min(flx1,y1),frx,y:=min(frx1,y1),条件是(x,y)可以走到(x1,y1)。转移顺序按照格子的海拔从小到大进行。第二步方法1:贪心。第二步方法2:动态规划。如果嫌时间多可以加上个单调队列去优化一下。事实上这题的瓶颈在于第1步,第一步方法1是O(N3)的,但是经过试验,我在这题加上了若干常数优化后,A掉了。详细的运行时间看下面的图片。新增一个最短路的方法:NOIP2010第四题引水入城最短路解法这道题目可以说正统的解法是找区间,然后再进行贪心。而经过我的研究发现,这题是可以用最短路来解决的!首先,那样例作为说明:首先,把每个格子当做一个点,

6、然后如果格子A的水能流到格子B,就从A到B连一条边现在称这个图为G。然后我们要构造一个G,就是把G所有边反向。下图为了后面描述方便,就把G的pic进行上下翻转了一下。然后,要构建主图H。主图H有M个点:A1,A2,A3.Am+1,对于任意1=i=m,从Ai+1到Ai连一条边。注意:这里的连边是按照编号逆序的。然后把G和G连到主图H上,G图最下面一层第i个点连到Ai+1上,然后Ai连到G图最下面一层第i个点。图如下(注:再说多一次,前一句的最下面一层是指对应原矩阵的最下面一层的点,这里的G图为了绘画方便,把图像进行了上下翻转操作):到目前为止,所有连到的边的权值都是0。最后,从G图最上面一层第i个点连一条权值为1的边到G图最上面一层第i个点。至此,图已建完:现在,点一共有O(NM)条,由于这是一个平面图,边与点同阶。所以边也有O(NM)条。现在可以用SPFA或者Dijkstra+Heap解决。如果考虑此图的特殊性(边权只有0和1),就可以采用最原始的BFS进行解决。至此,这题可以完美地转换为一个简单的最短路特殊模型了。PS:别问我建这个图的原理,想知道详情推导过程请参考NOI2008志愿者招募

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 高等教育 > 习题/试题

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号