POJ 3178 凸包+DP (巨坑)
题意:
思路:
这题巨坑!!!
这题巨坑!!!
这题巨坑!!!
这题巨坑!!!
这题巨坑!!!
(而且没有题解…….5555555……)
只能照着自己想的写了……
- 先求出来凸包
求凸包的方法呢:先找出来左下角的点 然后按照极角排序就OK了。
我用了两边sort
sort(point+1,point+1+n,cmp);
sort(point+2,point+1+n,cmp2);
第一遍sort:
bool cmp(Point a,Point b){
if(a.x==b.x)return a.y<b.y;
return a.x<b.x;
}
找出来左下角的点
第二遍sort:
bool cmp2(Point a,Point b){return (long long)(a.x-point[1].x)*(b.y-point[1].y)-(long long)(a.y-point[1].y)*(b.x-point[1].x)>0;}
按照极角找到了凸包 (注意是从2号点开始排的序)
Caution: tmd一定要用long long 100000*100000会挂的很惨 (我就是有一个点死活过不去 幸亏队长比较机智)
- 两边for暴力枚举一下两个柱子中间是否能连线段(相邻的不能连 所以j就从i+2–>n枚举好了)
一定要注意i=1&j=n的情况 (否则自己怎么死的都不知道)
ok[i][j]表示i能跟j相连
for(int i=1;i<=n;i++)
for(int j=i+2;j<=n;j++)
if(check(i,j)&&(i!=1||j!=n))ok[i][j]=1;
- 接下来就要挟坑爹的check函数了……
我的方法是余弦定理乱搞(乱搞都写错了……)
设A, B为线段的两个端点,C为圆心。
圆心到线段的距离<=r就不能连….
怎么求圆心到线段的距离呢 这时候要分情况讨论了
1.角A或者角B为钝角 这个时候只需判断AC和BC的距离是否大于r就OK了 (一开始我没有想到这个 挂的很惨)
2.知道三边 能够求出cosa(COSA=(B*B+C*C-A*A)/(2*B*C))
继而倒出SINA(cosa*cosa+sina*sina=1)
这个时候我发现 WOC!我的精度!!!!(OMG) 因为有些误差,相切的情况我没有判出来 囧么办? +个eps好了….
于是我就加了个eps
- 随后就是区间DP了
f[i][j]=max(f[i][k]+f[k][j])+ok[i][j]
(没有人傻到像我一样先枚举i,j,再枚举k了吧……)
(然后我就果断改了啊)
for(int lenth=2;lenth<=n;lenth++)
for(int start=1;start<=n;start++){
int end=start+lenth;
for(int k=start+1;k<min(end,n);k++)
f[start][end]=max(f[start][end],f[start][k]+f[k][end]);
f[start][end]+=ok[start][end];
}
这题真是步步为坑啊……………….
// by SiriusRen
#include <cmath>
#include <cstdio>
#include <algorithm>
using namespace std;
bool ok[255][255];
int n,g,r,f[255][155];
struct Point{int x,y;}point[255];
struct Circle{int x,y;}circle[255];
bool check(int a,int b){
double sx=1.0*point[a].x,sy=1.0*point[a].y;
double ex=1.0*point[b].x,ey=1.0*point[b].y;
double C=sqrt(1.0*(sy-ey)*(sy-ey)+1.0*(sx-ex)*(sx-ex));
for(int i=1;i<=g;i++){
double A=sqrt((circle[i].x-sx)*(circle[i].x-sx)+(circle[i].y-sy)*((circle[i].y-sy)));
double B=sqrt((circle[i].x-ex)*(circle[i].x-ex)+(circle[i].y-ey)*((circle[i].y-ey)));
double COSA=(B*B+C*C-A*A)/(2*B*C);
double COSB=(A*A+C*C-B*B)/(2*A*C);
if(COSA<1e-10||COSB<1e-10){
if(A<1.0*r+1e-10||B<1.0*r+1e-10)return 0;
else continue;
}
double SINA=sqrt(1-COSA*COSA);
double H=B*SINA;
if(H<1.0*r+1e-10)return 0;
}
return 1;
}
bool cmp(Point a,Point b){
if(a.x==b.x)return a.y<b.y;
return a.x<b.x;
}
bool cmp2(Point a,Point b){return (long long)(a.x-point[1].x)*(b.y-point[1].y)-(long long)(a.y-point[1].y)*(b.x-point[1].x)>0;}
int main(){
scanf("%d%d%d",&n,&g,&r);
for(int i=1;i<=n;i++)
scanf("%d%d",&point[i].x,&point[i].y);
sort(point+1,point+1+n,cmp);
sort(point+2,point+1+n,cmp2);
for(int i=1;i<=g;i++)
scanf("%d%d",&circle[i].x,&circle[i].y);
for(int i=1;i<=n;i++)
for(int j=i+2;j<=n;j++)
if(check(i,j)&&(i!=1||j!=n))ok[i][j]=1;
for(int lenth=2;lenth<=n;lenth++)
for(int start=1;start<=n;start++){
int end=start+lenth;
for(int k=start+1;k<min(end,n);k++)
f[start][end]=max(f[start][end],f[start][k]+f[k][end]);
f[start][end]+=ok[start][end];
}
printf("%d\n",f[1][n]);
}
整整写了一天啊……….
POJ 3178 凸包+DP (巨坑)的更多相关文章
- 【走过巨坑】android studio对于jni调用及运行闪退无法加载库的问题解决方案
相信很多小伙伴都在android开发中遇到调用jni的各种巨坑,因为我们不得不在很多地方用到第三方库so文件,然而第三方官方通常都只会给出ADT环境下的集成方式,而谷歌亲儿子android studi ...
- 【单页应用巨坑之History】细数History带给单页应用的噩梦
前言 在我们日常的网页浏览中,我们非常喜欢做一个操作:点击浏览器的前进后退在Ajax技术出现后,有些时候前进后退就会给开发者带来困扰,甚至一些开发者试图去干掉History随着Html5的发展,移动端 ...
- bat调用bat的一个巨坑
[一个巨坑] a.bat的内容:echo 1b.batecho 2执行结果:运行a.bat时,输出1,然后调用b.bat, 但是 echo 2 显示不出来. bat怎么调用bat文件并返回? 例如主文 ...
- QJsonObject和QJsonArray的巨坑
最近用Qt的QJsonObject和QJsonArray当做类变量来存储运行信息,发现这两货真的是巨坑.让人有一种JJ fly的感觉/(ㄒoㄒ)/~~. 写了个例子来说明下: MainWindow:: ...
- poj 1873 凸包+枚举
The Fortified Forest Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 6198 Accepted: 1 ...
- poj 1113 凸包周长
Wall Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 33888 Accepted: 11544 Descriptio ...
- better-scroll之吸顶效果巨坑挣扎中
今天和大家分享下better-scroll这款移动端用来解决各种滚动需求的插件(目前已经支持PC) 关于其中的API大家可以去官网看下 这里就给大家介绍几种常用的以及需要注意的点是什么 首先说一下b ...
- (杭电 2054)A==B?(这真是个巨坑)
A == B ? Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...
- SpriteKit在复制节点时留了一个巨坑给开发者,需要开发者手动把复制节点的isPaused设置为false
根据When an overlay node with actions is copied there is currently a SpriteKit bug where the node’s is ...
随机推荐
- [JavaEE]Hibernate 所有缓存机制详解
Hibernate提供的一级缓存 hibernate是一个线程对应一个session,一个线程可以看成一个用户.也就是说session级缓存(一级缓存)只能给一个线程用,别的线程用不了,一级缓存就是和 ...
- Vmware 安装samba之二
安装samba:sudo apt-get install samba 安装smbclient:sudo apt-get install 安装smbfs:sudo apt-get smbfs 2.修改配 ...
- javascript前端如何使用google-protobuf
1.首先下载google的protobuf的compiler,通过编译器可以将.proto文件转换为想要的语言文件. 下载地址:https://repo1.maven.org/maven2/com/g ...
- Response.Redirect(),Server.Transfer(),Server.Execute()的区别与网站优化
转 http://blog.csdn.net/dannywj1371/article/details/10213631 1.Response.Redirect():Response.Redirect方 ...
- 转:Eclipse上安装GIT插件EGit及使用
一.Eclipse上安装GIT插件EGit Eclipse的版本eclipse-java-helios-SR2-win32.zip(在Eclipse3.3版本找不到对应的 EGit插件,无法安装) E ...
- httpclient定时请求实例
1.pom.xml <properties> <slf4j.version>1.7.21</slf4j.version> <okhttp.version> ...
- windows 下安装 php-memcached 扩展
通过 phpinfo()观察 3 个参数,即 php 版本, ts/nts, vc6/vc9 根据上步中的参数,到http://pecl.php.net/ 下载匹配的 memcache.dll 再次观 ...
- ubuntu16.04 安装 docker-compose
下载安装 docker-composecurl -L https://github.com/docker/compose/releases/download/1.15.0/docker-compose ...
- 开发工具 | 利用 deployd 搭建个人博客
前端er,通过利用deployd + mongodb,实现可视化的接口编写,自定义mock数据,数据存储在mongodb中:deployd目前还没有中文网,更多信息请参考http://deployd. ...
- art-template模板渲染及其过滤器
原生语法 使用原生语法,需要导入template-native.js文件.在HTML中定义模板,注意模板的位置,不要放到被渲染区域,防止模板丢失. <script id="tpl&qu ...