有一张长方形的薄片,里面有宽x高的方形瓷砖。薄板可以被分成两个矩形的碎片,从边缘,水平或垂直。
例如,2x2页可以分为两个2x1部分,但不能分成两个部分,其中一个是1x1。纸张可以被划分多少次,我们想要多少。
我想要创造至少一件,其中包括确切的T瓷砖。如何找到达到这一目标所需的最小数目的拆分操作?
例如。如果,宽度=5,高度=4,T= 8,那么最小的分裂数=?
第一次分裂将有两个部分: 2x4,3x4。2x4 =8,等于T.分裂数= 1。
我有蛮力的解决方案,通过它,我可以找到在一张纸中获得T瓷砖所需的最小分裂数,但我正在寻找优化的一个。有什么帮助或建议吗?
发布于 2014-07-19 16:48:13
让n和m成为板的宽度和高度。
在某些情况下(即1和2)解决方案的复杂性。是O(1),但在一般情况下(3.)这是O(sqrt ),因为当我们检查所有对(a,b)时,a*b =T,那么MIN(a,b) <= sqrt(T) --这也是在搜索某个数的除数时常用的技巧。
https://stackoverflow.com/questions/24842426
复制相似问题