设S( x1 ,x2 ,y1, y2)为操作后只有( x1 ,x2 ,y1, y2)区间内的硬币留下的最小步数, 令Xleft=x1,  Xright=m-1-x2   Yup=y1,   Ydown=n-1-y2 则S( x1 ,x2 ,y1, y2)=2(Xleft+Xright+Yup+Ydown)-max(Xleft , Xright)-max(Yup , Ydown) 然后求出所有区间 ( x1 ,x2 ,y1, y2)硬币数为k的S,并取最小值。 求某个区间的硬币数量可以利用动态规划,预处理后每次求都是O(1)的复杂度。 枚举y1  y2  x1,则x2为满足硬币数不多于k的最大值。 所以总复杂度为O(n^2*m)。
点赞 1

相关推荐

04-15 23:42
中山大学 Java
ResourceUtilization:过几天楼主就会捧着一堆offer来问牛友们该怎么选辣
点赞 评论 收藏
分享
白火同学:大二有这水平很牛了,可以适当对关键信息加粗一点,比如关键技术、性能指标之类的。
点赞 评论 收藏
分享
牛客网
牛客网在线编程
牛客网题解
牛客企业服务