讲稿coci2011 contest3 mono解题报告.pdfVIP

  1. 1、本文档共1页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

coci2011contest3mono解题报告

——长沙市雅礼中学

[关键字]位移拆分

[试题大意]

给一个最大500*500的字母矩阵,并给一个边平行于坐标轴的最多500个

顶点的多边形,这个矩形可以左右上下位移,问有多少种位移方法,使得多边

形内的字母相等。

[解题报告]

首先看到此题,首先容易想到将矩阵的位移改为多边形的位移。

不难想到,我们要枚举多边形的左上角位置,然后判断多边形内的格子是

24

否相同,由于格子是O(N)级别,所以这个算法是O(N)级别,会超时。

这提示我们要将部分格子一起判断,因为在格子中我们能够快速一起判断

的比较方便的是矩形,我们尝试想办法将原来的多边形转化为若干矩形合并的

判断问题。

最容易想到的思路无非就是平时我们离散化的方法,将V个点的X,Y坐标

离散出来,这样离散化出来的格子是O(V2)级别,仍然无法通过所有数据。

回忆我们离散化时的思想,不难发现实际上因为两个格子的情况一样可以

2

合并计算,容易发现上述离散化中仍然存在冗余,因为O(V)个格子里面也

有很多格子可以合并计算,过于强硬的照搬离散化思想是不行的。

我们来考虑下面这样一个过程,每次找到最左上方的一个格子,然后向右

找到连续一段极长的格子,然后向下拓展直到找到一个极大子矩形,这样再将

这些格子去掉重复上述过程。我们就能将这个多边形分成若干矩形,容易发现

这些矩形个数与点数同级。

这样我们可以枚举所有位移然后用矩形判断是否可行来计算答案。

[时间复杂度]O(N*M*V)

[总结]

此题最重要的思想就是要去思考冗余部分应该如何简化,才能优化算法。

文档评论(0)

187****4471 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档