hihoCoder#1042 跑马圈地
经网友jokeren提醒,后面给出的代码虽然可以AC原题,但存在bug,主要是在矩形覆盖情况的判断上处理的不够完全。
看似挺复杂的,但是仔细分析一下可以化简:
首先,不用枚举周长,因为更长的周长总是能够围成更大的面积,所以只要考虑如何在周长为L的前提下枚举面积就行了。
下图中,用蓝色线框表示跑马的路线,灰色矩形表示臭水塘。
假设可以穿越臭水塘,那么:圈地面积=蓝矩形面积 - 蓝矩形内部的灰色矩形面积。
现在不让穿越臭水塘,为了维持面积不变,就需要绕着臭水塘走:
注意:绕路以后,面积不变。
上面这个例子说明:不管你怎么跑马,圈出什么形状的地,都可以转化成一个蓝矩形和黑矩形覆盖的情况(当然如果二者不相交就更简单了)。
所以,不用去考虑圈地的形状,只需要枚举蓝矩形面积,然后减掉臭水塘的面积,就是圈地的面积。
上面的转化看上去很美好,但问题来了,虽然面积不变,但周长可能会变化。仔细分析,一共有这几种情况:
情况I:绕路以后,周长不变:
情况II:绕路以后,周长增加:
情况III:绕路以后,周长变小:
情况IV:矩形不相交,无变化:
情况V:蓝矩形覆盖灰矩形,无变化:
情况VI:这种情况是不合法的,遇到就直接跳过吧:
情况I、IV、V最好,直接计算即可
情况II不考虑,因为周长爆了,不满足周长等于L的条件
情况III也不考虑,因为当计算两个矩形不相交的时候会覆盖到这种情景。
所以,只需要考虑情况I、IV、V即可,是不是瞬间变简单了!
那如何判断是情况I、IV、V呢?
仔细观察,可以发现矩形的重叠情况跟灰矩形在蓝矩形内部的点的数量有关:
如果灰矩形在蓝矩形内部的顶点数分别对应了上面的几种情况。需要注意的是,顶点数为0实际上对应情况V和情况VI,但因为情况VI是非法的,所以这里需要额外判断一下。
代码:
#include <iostream> using namespace std; int n, m, L;
int l, r, t, b; int run_horse(int pl, int pr, int pt, int pb) {
int ll = max(l, pl);
int rr = min(r, pr);
int tt = max(t, pt);
int bb = min(b, pb); if (ll >= rr || tt >= bb)
return (pr - pl) * (pb - pt); int inside = ;
if (ll > pl && ll < pr && tt > pt && tt < pb)
inside++;
if (rr > pl && rr < pr && tt > pt && tt < pb)
inside++;
if (ll > pl && ll < pr && bb > pt && bb < pb)
inside++;
if (rr > pl && rr < pr && bb > pt && bb < pb)
inside++; if (inside == || inside == )
return (pr - pl) * (pb - pt) - (rr - ll) * (bb - tt);
else
return ;
} int main() {
int res = ; cin >> n >> m >> L;
cin >> l >> r >> t >> b; for (int i = ; i < n; i++) {
for (int j = ; j < m; j++) {
int w = ;
int h = (L - * w) / ;
while (w > && h > ) {
res = max(res, run_horse(j, min(m, j + w), i, min(n, i + h)));
w++;
h = (L - * w) / ;
}
}
} cout << res << endl;
}
hihoCoder#1042 跑马圈地的更多相关文章
- BAT带队烧钱圈地华为们猛追云计算
在和一位创业者交流时,他说现在创业者想从市场脱颖而出太难了,且不论创业本身的不易,更多时候是想做的事情都被BAT广撒网覆盖了. 现实也正是如此,包括影业.在线音乐.车联网等领域,BAT都已涉足.如今, ...
- 不融资、不上市、不快马圈地…“佛系”ZOHO的中国生意经
来源:钛媒体 作者:秦聪慧 "技术比肩SAP.直追微软的这家25岁"非典型"国际大厂会继续佛系下去吗? ZOHO研发中心大楼 在中国,有家相对低调的"舶来&qu ...
- 许小年:宁可踏空,不可断粮<转>
http://www.daonong.com/g/25/xsqy/2014/0716/51074.html 文│许小年 中欧国际工商学院教授 为什么我们企业的创新能力长期处于低水平呢? 深入观察,内心 ...
- SAP的吐槽来源
这几天看了 梅林传奇(英国剧) , 封面是 梅林传奇的男主 对着女主 一脸无语的玩着电脑. 原来 看梅林传奇的时候,以为自己看错了,没有理会到这部剧的真谛,是自己不懂得和发现美,为了滚娘从第二季就弃了 ...
- 地理数据可视化:Simple,Not Easy
如果要给2015年的地理信息行业打一个标签,地理大数据一定是其中之一.在信息技术飞速发展的今天,“大数据”作为一种潮流铺天盖地的席卷了各行各业,从央视的春运迁徙图到旅游热点预测,从大数据工程师奇货可居 ...
- 传统企业,"哀兵必胜"的想法要不得
[文/ 任英杰]同事在内网上发了一篇文章『哀兵必胜』,思量数日,作文应对.文中表达的积极精神让人敬佩,但背后似乎隐含着一股莫名的“情绪”.对行业大格局的基本看法会影响公司转型的成败,觉得还是有必要讨论 ...
- 如何实现室内Wi-Fi无线终端的精准定位
如何实现室内Wi-Fi无线终端的精准定位 如何实现室内Wi-Fi无线终端的精准定位 随着商圈020的兴起,室内定位技术的也如百花争艳般不断涌现.但随着室内Wi-Fi网的架设普及,基于Wi-Fi定位技术 ...
- 收藏:左路Deep Learning+右路Knowledge Graph,谷歌引爆大数据
发表于2013-01-18 11:35| 8827次阅读| 来源sina微博 条评论| 作者邓侃 数据分析智能算法机器学习大数据Google 摘要:文章来自邓侃的博客.数据革命迫在眉睫. 各大公司重兵 ...
- TD-SCDMA风雨20年:中国3G标准的由来以及国家通信战略
.国际电信标准是咋回事? 当年作为通信专业的学生,我曾长期困惑一个问题,为什么同一项通信技术总会有美国和欧洲两种国际标准?比如电话语音的数字化就有欧洲A律和美国u(谬)律两种. 学习后发现,两种标准的 ...
随机推荐
- Kay and Snowflake CodeForces - 686D
Kay and Snowflake CodeForces - 686D 题意:给一棵有根树,有很多查询(100000级别的),查询是求以任意一点为根的子树的任意重心. 方法很多,但是我一个都不会 重心 ...
- How many Fibs? POJ - 2413
How many Fibs? POJ - 2413 高精模板 #include<cstdio> #include<cstring> #include<algorithm& ...
- 题解报告:hdu 1754 I Hate It(线段树)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1754 Problem Description 很多学校流行一种比较的习惯.老师们很喜欢询问,从某某到某 ...
- 转 SQL*PLUS中的替换变量(& &&)
今天oracle support提供一个脚本,大致如下: PROMPT ROUTING_SEQUENCE_ID = &ROUT_SEQ_ID PROMPT OPERATION_SEQUENCE ...
- Codeforces Round #138 (Div. 1)
A 记得以前做过 当时好像没做对 就是找个子串 满足括号的匹配 []最多的 开两个栈模拟 标记下就行 #include <iostream> #include<cstring> ...
- java数据结构和算法04(链表)
前面我们看了数组,栈和队列,大概就会这些数据结构有了一些基本的认识,首先回顾一下之前的东西: 在数组中,其实是分为有序数组和无序数组,我简单实现了无序数组,为什么呢?因为有序数组的实现就是将无序数组进 ...
- Android GetTimeAgo(时间戳转换几天前,几分钟前,刚刚等)
package com.studychen.seenews.util; import android.content.Context; /** * Created by tomchen on 2/26 ...
- 总结几点sql语句优化
一.表设计阶段: 1.主键的使用 a.业务日志表.安全审计表采用自增长: b.自定义编号用于业务流程类表,根据一定的编号规则: c.int型主键 用于基础数据表: 2.逻辑删除字段的 ...
- bindtextdomain - 设置 包括 消息条目 的 路径
总览 (SYNOPSIS) #include <libintl.h> char * bindtextdomain (const char * domainname, const char ...
- RackTables在LNMP系统的安装及使用
RackTables是一款优秀的机房管理系统,可以十分方便的登记机房设备和连接情况,非常适合小型机房的运维.RackTables是PHP开发的免费系统,最新版本为0.20.14,PHP版本要求不低于P ...