[FJSC2014]圈地

【题目描述】

  2维平面上有n个木桩,黄学长有一次圈地的机会并得到圈到的土地,为了体现他的高风亮节,他要使他圈到的土地面积尽量小。圈地需要圈一个至少3个点的多边形,多边形的顶点就是一个木桩,圈得的土地就是这个多边形内部的土地。(因为黄学长非常的神,所以他允许圈出的第n点共线,那样面积算0)

【输入格式】

  第一行一个整数n,表示木桩个数。
  接下来n行,每行2个整数表示一个木桩的坐标,坐标两两不同。

【输出格式】

  仅一行,表示最小圈得的土地面积,保留2位小数。

【样例输入】

样例1:
3

0 0

0 1

1 0

样例2:
4

0 0

0 1

0 2

1 1

【样例输出】

样例1:
0.50
样例2:
0.00
【数据范围】

  对于10%的数据,n<=100;
  对于30%的数据,n<=300;
  对于50%的数据,n<=500;
  对于100%的数据,n<=1000。

Solution

  这题被我乱搞搞掉了= =

  暴力n^3不多说。但是有很多时候的情况是没有用的。于是我们把这些点分成sqrt(n)块,块内暴力,轻松愉快。

  这样做不靠谱,所以我们可以随机旋转坐标系,rand个四五十次就可以把这题水过了。

出题人题解:

  显然,这时候暴力枚举会T。于是我们转变一下思路,如果我们确定了2个点以后,第三个点有必要去盲目的枚举吗?答案是否定的。实际上我们把经过这两点的线看成一个斜率,把他当成y轴你会发现第三个点明显是在坐标系左右找一个离”y轴”最近的点来算面积更新答案。然后我们可以继续思考,发现我们可以把点按照某个斜率当成”y轴”进行“从左到右”的排序,这样当2点共线的时候,用这两个点的左右2个点去更新答案就好了。也就是说我们采用旋转坐标系的方法,一开始按x坐标排好序,认为直接用竖着的那条斜率,然后维护的话每次其实当两点共线后只要交换他们就能得到斜率转过该事件点的序列。所以我们可以预处理出所有可行的斜率,当成事件点,不断转动坐标系更新答案就好。这样复杂度只有n^2,期望得分100.(这确实只是个暴力的优化 啊。。。不要砸我T_T)

(好像很复杂的样子。。。)

 1 #include<cstdio>
 2 #include<ctime>
 3 #include<cstdlib>
 4 #include<cmath>
 5 #include<algorithm>
 6 const double pi=3.1415926535897932384626;
 7 struct P{double x,y;}a[1010],z,b[1010];int n,k;double ans=1e10,tmp,t;
 8 bool operator<(P const&a,P const&b){return a.x<b.x||(a.x==b.x&&a.y<b.y);}
 9 P operator+(P const&a,P const&b){return (P){a.x+b.x,a.y+b.y};}
10 P operator-(P const&a,P const&b){return (P){a.x-b.x,a.y-b.y};}
11 P operator*(P const&a,double p){return (P){a.x*p,a.y*p};}
12 P operator*(P const&a,P const&b){return (P){a.x*b.x-a.y*b.y,a.x*b.y+a.y*b.x};}
13 double cross(P const&a,P const&b){return a.x*b.y-a.y*b.x;}
14 double dot(P const&a,P const&b){return a.x*b.x+a.y*b.y;}
15 int main()
16 {
17     scanf("%d",&n);int i,j;k=(int)sqrt(n)+10;//srand(time(0));
18     for(i=1;i<=n;i++)scanf("%lf%lf",&a[i].x,&a[i].y);
19     if(n<=300)
20     {
21         for(i=1;i<n;i++)
22         for(j=i+1;j<n;j++)
23         for(k=j+1;k<=n;k++)
24         {
25             tmp=std::abs(cross(a[k]-a[i],a[j]-a[i]));
26             if(ans>tmp)ans=tmp;
27         }
28         printf("%.2lf\n",ans/2.0);
29     }
30     else{int p1=31,p2=23;
31         for(int tt=1;tt<=p1;tt++)
32         {
33             z=(P){cos(pi/p2*tt),sin(pi/p2*tt)};
34             for(i=1;i<=n;i++)b[i]=a[i]*z;
35             std::sort(b+1,b+1+n);
36             for(int kk=1;(kk-1)*k<=n;kk++)
37             for(i=(k*(kk-1)+1);i<n&&i<k*kk;i++)
38             for(j=i+1;j<n&j<k*kk;j++)
39             for(int l=j+1;l<=n&&l<k*kk;l++)
40             {
41                 tmp=std::abs(cross(b[l]-b[i],b[j]-b[i]));
42                 if(ans>tmp)ans=tmp;
43             }
44         }
45         printf("%.2lf\n",ans/2.0);
46     }
47 }

[FJSC2014]圈地

时间: 2024-10-16 14:18:49

[FJSC2014]圈地的相关文章

《善圈第26期天天圈》:善圈520,鞠躬迎老兵!

亮点:<善圈第26期天天圈>5.20今日精彩回顾:善圈520,鞠躬迎老兵! 深圳罗湖京基100大厦71层善圈,今天迎来了一位尊贵的客人,他是共和国功臣,一位抗美援朝的英雄老兵--现年83岁的老爷爷陈碧.只见他身穿昔日的绿色军装,挂满了各种军功章. 老人家精神矍铄地向大家行军礼,参加学习的企业家纷纷与老人家合影留念,聆听英雄老兵讲述峥嵘岁月的战斗故事. 著名作家魏巍<谁是最可爱的人>将人们的记忆,回放到60多年前那场让全世界为之瞩目的抗美援朝战争.曾经多少优秀中华儿女,雄赳赳气昂昂跨

iOS Core Image-----十行代码实现微信朋友圈模糊效果

昨天下午微信的朋友圈着实火了一把,在这之后好多程序员都通过抓包工具看到了原图,但是我却在想,网上说是在移动前端做到的那是怎么做到的呢,经过一些学习,终于掌握了一些Core Image的知识,做出了相应的效果,仅仅十行代码 UIImageView * imgView = [[UIImageView alloc]init]; imgView.frame = CGRectMake(50, 50, 200, 200); [self.view addSubview:imgView]; UIImage *

基于微信群控系统分析几十万几百万用户微信朋友圈和聊天记录数据

基于微信群控系统分析几十万几百万用户朋友圈和聊天记录数据打造针对用户的智能推荐系统 用户属性: 姓名.性别.年龄.所在地区.常驻地区.手机号码.微信号码.职业.岗位.身份证等等 用户行为:1.通过图文分析,定位所在区域.行业.大概的收入状况.喜好:2.如果是微商,分析常发微信圈产品:3.综合分析朋友圈人气状况:4.给用户打标签:5.产品匹配. 建立用户画像标签和大数据分析实现智能推荐系统 需要用到的技术 朋友圈抓取技术.高并发架构.大数据分析架构 安卓开发 python  mongodb spa

h5+分享到微信、朋友圈代码示例

(function(window) { var Share={}; Share.info = { id: '', name: '', head_image: "_www/images/icon/A/144.png", introduce: '' }; /** * 更新分享服务 */ var shares = null; function getSerivces() { plus.share.getServices(function(s) { shares = {}; for (var

Android 微信分享,分享到朋友圈与分享到好友,以及微信登陆

extends:http://www.cnblogs.com/android100/p/Android-qq.html 一.申请你的AppID http://open.weixin.qq.com/ 友情提示:推荐使用eclipse打包软件最后一步的MD5值去申请AppID 二.官网下载libammsdk.jar包 http://open.weixin.qq.com/download/?lang=zh_CN 三.将libammsdk.jar复制到工程的libs目录 四.在需要分享的Activity

10.EVE-NG镜像来啦!打造国内最大的EVE交流圈

文章列表(关注微信公众号EmulatedLab,及时获取文章以及下载链接) 1.EVE-NG介绍(EVE-NG最好用的模拟器,仿真环境时代来临!) 2.EVE-NG安装过程介绍 3.EVE-NG导入Dynamips和IOL 4.EVE-NG导入QEMU镜像 5.EVE-NG关联SecureCRT,VNC,Wireshark 6.EVE-NG网卡桥接,带您走进更高级的实验 7.EVE-NG硬盘扩容,存储海量镜像 8.EVE-NG定制个人镜像,脚本快速导入 9.EVE-NG容纳H3C.Huawei,

android 滚动栏下拉反弹的效果(相似微信朋友圈)

微信朋友圈上面的图片封面,QQ空间说说上面的图片封面都有下拉反弹的效果,这些都是使用滚动栏实现的.下拉,当松开时候.反弹至原来的位置.下拉时候能看到背景图片.那么这里简介一下这样的效果的实现. 本文源代码下载:点击 1.效果图 这部手机显示的分辨率有限,非常老的手机调试. 2.具有反弹效果BounceScrollView package com.org.scroll; import android.content.Context; import android.graphics.Rect; im

HDU3342有向图判圈DFS&amp;&amp;拓扑排序法

HDU3342 Legal or Not 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3342 题目意思:一群大牛互相问问题,大牛有不会的,会被更厉害的大牛解答,更厉害的大牛是会的东西比大牛多,但是有的时候更厉害的大牛会装弱,出来问问题,这样就被大牛解答了.这样就形成了一个圈.题目的意思就是让你在一个有向图里面判断是否存在环.我们可以通过dfs和拓扑排序两种方法. DFS的代码: //Author: xiaowuga #include <bits

android网页分享到朋友圈问题求助?

目前想要实现通过QQ将网页分享到微信好友或朋友圈,看见有些APP是直接分享出去左下角图标显示的是QQ.求助各位大牛提供下思路. 这种功能是怎么实现的.应该不是通过android的系统分享实现的吧?.查了几天的资料仍然没有思路,求助各位大牛 这种功能是怎么实现的.应该不是通过android的系统分享实现的吧?.查了几天的资料仍然没有思路,求助各位大牛 这种功能是怎么实现的.应该不是通过android的系统分享实现的吧?.查了几天的资料仍然没有思路,求助各位大牛 这种功能是怎么实现的.应该不是通过a