`
huobengle
  • 浏览: 862014 次
文章分类
社区版块
存档分类
最新评论

USACO Section 3.1 Shaping Regions - 矩阵切割..

 
阅读更多


开始听对里的大大说这是二维线段树..没敢写..后来再一想..数据范围N<=2500..那么N^2的算法可以过...再一想...其实就是拿到一个矩阵然后和以后填上去的矩阵来比较..去掉重合的部分..将矩阵切割成若干小矩阵..然后这些小矩阵再继续往后面看有没有和后面填的矩阵重合的矩形区域(矩形和矩形重合的区域也一定是矩形)..有的做相同的操作...后来才知道这就是矩阵切割..时间复杂度是N^2..可以接受..用递归来实现很方便..递归时我就假想当前矩阵的重复区域矩形是在当前这个矩形内部的..那么为了切掉这个重复的中间部分..那么我要把这个矩形切成四块.如图:


就让他这么切..为了防止一些切出来不满足要求或者切出来面积为0没有意义的区域..那么就在递归的时候加个判断.看当前的矩形是否是合法的..也就是lx<ux && ly<ux

Program:



分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics