实话说这个题就是个暴力,但是有坑,第一次我以为相含是不行的,结果WA,我加上相含以后还WA,我居然把这两个矩形的面积加在一块了吗,应该取大的那一个啊……

  方法就是枚举对角线,为了让自己不蒙圈,我写了一个矩阵类,可以实现自动判断是否能成功形成矩阵,自动排序四个点,返回面积,方便以后的判断。

  C++面向对象大法好……

  代码及注释如下:

  

#include<bits/stdc++.h>
using namespace std;
#define MaxN 55
#define MaxM 222
struct Pos{
int x,y;
void Set(int x1,int y1)
{
x = x1;
y = y1;
}
}p[MaxN];
int isp[MaxM][MaxM],n;
bool cmp(Pos a,Pos b){
if(a.x != b.x) return a.x < b.x;
return a.y < b.y;
}
class Rec{
public:
Pos k[];
int area;
bool Creat(Pos a,Pos b){
k[].x = a.x,k[].y = a.y;
k[].x = b.x,k[].y = b.y;
k[].x = a.x,k[].y = b.y;
k[].x = b.x,k[].y = a.y;
sort(k,k+,cmp);///排序便于判断
area = abs(a.x-b.x)*abs(a.y-b.y);
for(int i = ;i < ;i++){
int tx = k[i].x,ty = k[i].y;
if(isp[tx][ty]==) {
return false;
}
}
return true;
}
};
bool Equal(Pos a,Pos b){
return (a.x==b.x && a.y==b.y);
}
bool All_in(Pos a,Pos b,Pos c){
return (c.x>a.x && c.x<b.x && c.y>a.y && c.y<b.y);
}
bool Part_in(Pos a,Pos b,Pos c){
return (c.x>=a.x && c.x<=b.x && c.y>=a.y && c.y<=b.y);
}
int Check(Rec a,Rec b){
for(int i = ;i < ;i++){///判断重复点
if(Equal(a.k[i],b.k[i])) return ;
}
int tot1 = ,tot2 = ;
for(int i = ;i < ;i++){///先判断是否两个相含
if(All_in(a.k[],a.k[],b.k[i])) tot1++;
if(All_in(b.k[],b.k[],a.k[i])) tot2++;
}
if(tot1 == || tot2 == ) {
return ;
}
for(int i = ;i < ;i++){///不是相含,就必须相离
if(Part_in(a.k[],a.k[],b.k[i])) return ;
if(Part_in(b.k[],b.k[],a.k[i])) return ;
}
return ;
}
int Get_ans(){
int ans = -;
Rec a,b;
for(int i = ;i < n;i++)///枚举对角线
{
for(int j = i+;j < n;j++)
{
if(p[i].x==p[j].x || p[i].y==p[j].y) continue;
if(a.Creat(p[i],p[j]) == false) continue;
for(int k = ;k < n;k++)
{
for(int q = k+;q < n;q++)
{
if(p[k].x==p[q].x || p[k].y==p[q].y) continue;
if(b.Creat(p[k],p[q]) == false) continue;
int c = Check(a,b);
if(c == ) ans = max(ans,a.area+b.area);
if(c == ) ans = max(ans,max(a.area,b.area));
///相含的话,选择较大的面积
}
}
}
}
return ans;
}
int main()
{
// freopen("B.in.cpp","r",stdin);
int x,y;
while(cin>>n && n)
{
memset(isp,,sizeof(isp));
for(int i = ; i < n; i++)
{
cin>>x>>y;
p[i].Set(x,y);
isp[x][y] = ;
}
int ans = Get_ans();
if(ans == -) cout<<"imp"<<endl;
else cout<<ans<<endl;
}
return ;
}

UVALive 7070 The E-pang Palace(暴力)的更多相关文章

  1. UVALive 7070 The E-pang Palace 暴力

    The E-pang Palace Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudge/problem ...

  2. 简单几何(判断矩形的位置) UVALive 7070 The E-pang Palace(14广州B)

    题目传送门 题意:给了一些点,问组成两个不相交的矩形的面积和最大 分析:暴力枚举,先找出可以组成矩形的两点并保存起来(vis数组很好),然后写个函数判断四个点是否在另一个矩形内部.当时没有保存矩形,用 ...

  3. UVaLive 6855 Banks (水题,暴力)

    题意:给定 n 个数,让你求最少经过几次操作,把所有的数变成非负数,操作只有一种,变一个负数变成相反数,但是要把左右两边的数加上这个数. 析:由于看他们AC了,时间这么短,就暴力了一下,就AC了... ...

  4. UVALive 2145 Lost in Space(暴力)

    题目并不难,就是暴力,需要注意一下输出形式和精度. #include<iostream> #include<cstdio> #include<cmath> usin ...

  5. The E-pang Palace(暴力几何)

    //暴力的几何题,问,n个点可以组成的矩形,不相交,可包含的情况下,最大的面积,还有就是边一定与 x y 轴平行,所以比较简单了 //暴力遍历对角线,搜出所有可能的矩形,然后二重循环所有矩形,判断一下 ...

  6. UVALive 6862 Triples (找规律 暴力)

    Triples 题目链接: http://acm.hust.edu.cn/vjudge/contest/130303#problem/H Description http://7xjob4.com1. ...

  7. UVALive 7457 Discrete Logarithm Problem (暴力枚举)

    Discrete Logarithm Problem 题目链接: http://acm.hust.edu.cn/vjudge/contest/127401#problem/D Description ...

  8. UVALive - 6837 Kruskal+一点性质(暴力枚举)

    ICPC (Isles of Coral Park City) consist of several beautiful islands. The citizens requested constru ...

  9. HDU - 5128The E-pang Palace+暴力枚举,计算几何

    第一次写计算几何,ac,感动. 不过感觉自己的代码还可以美化一下. 传送门:http://acm.hdu.edu.cn/showproblem.php?pid=5128 题意: 在一个坐标系中,有n个 ...

随机推荐

  1. linux安装GraphicsMagick

    下载GraphicsMagick-1.3.21.tar.gz 解压:tar -zxvf GraphicsMagick-1.3.21.tar.gz cd /usr/local/GraphicsMagic ...

  2. Win内存分配函数(GlobalAlloc/HeapAlloc/LocalAlloc/VirtualAlloc)

    Win内存分配函数(GlobalAlloc/HeapAlloc/LocalAlloc/VirtualAlloc) 来源:http://blog.csdn.net/chunyexiyu/article/ ...

  3. tomcat + jenkins启动tomcat后打开jenkins页面提示404错误的解决方案

    首先下载tomcat和jenkins,将下载的jenkins2.12 war放到tomcat的webapps文件夹下后执行/bin文件夹下的start启动后,打开http://localhost:80 ...

  4. ubuntu14.04下安装ice3.5.1

    ubuntu 14.04下是可以通过下面这条指令安装ice3.5的 sudo apt-get install libzeroc-ice35-dev 1. 从这里下载ice源文件 主要包括两部分:ice ...

  5. (repost)在ARM Linux内核中增加一个新的系统调用

    实验平台内核版本为4.0-rc1,增加一仅仅打印Hello World的syscall,最后我们在用户空间swi验证 实验平台内核版本为4.0-rc1,增加的系统调用仅仅是简单打印一个Hello Wo ...

  6. 优秀代码要求(转自http://www.cnblogs.com/brishenzhou/p/6284188.html)

    一段优秀的代码,它一般需要满足以下几个条件: #统一规范# 所有的代码,第一前提必须是统一规范,而常见的统一规范主要包括有以下内容: 1)统一编辑器规范 在团队开发中,我们并不对各个开发人员使用的编辑 ...

  7. echarts样式修改

    本人是查看如下链接: http://down.admin5.com/demo/code_pop/cs/dsj/doc/example/themeDesigner.html# 图示很简洁明了.

  8. java 图形界面 邮件系统

    将后台的邮件系统使用javaGUI编程来实现,让我们可以在桌面端直接控制邮件的收发功能. 一.实现邮箱的登陆功能 邮件系统使用smtp协议发送邮件,使用POP3协议或者IMAP协议来收取邮件.SMTP ...

  9. NewtonJson中转义的斜杠\和多余的引号处理

    使用newtonjson序列化的json串正常的,但通过网络传输后,会再包装一层引号和对原有定义引号的转义,最后结果就变成这种数据: “\"{\\\"State\":fa ...

  10. html .css 实现图片滑动和自动播放特效移动端 HTML 5中添加了以touch 开头的事件

    <!DOCTYPE HTML> <html> <head> <meta charset="utf-8">     <meta ...