题意:



思路:

这题巨坑!!!

这题巨坑!!!

这题巨坑!!!

这题巨坑!!!

这题巨坑!!!

(而且没有题解…….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 (巨坑)的更多相关文章

  1. 【走过巨坑】android studio对于jni调用及运行闪退无法加载库的问题解决方案

    相信很多小伙伴都在android开发中遇到调用jni的各种巨坑,因为我们不得不在很多地方用到第三方库so文件,然而第三方官方通常都只会给出ADT环境下的集成方式,而谷歌亲儿子android studi ...

  2. 【单页应用巨坑之History】细数History带给单页应用的噩梦

    前言 在我们日常的网页浏览中,我们非常喜欢做一个操作:点击浏览器的前进后退在Ajax技术出现后,有些时候前进后退就会给开发者带来困扰,甚至一些开发者试图去干掉History随着Html5的发展,移动端 ...

  3. bat调用bat的一个巨坑

    [一个巨坑] a.bat的内容:echo 1b.batecho 2执行结果:运行a.bat时,输出1,然后调用b.bat, 但是 echo 2 显示不出来. bat怎么调用bat文件并返回? 例如主文 ...

  4. QJsonObject和QJsonArray的巨坑

    最近用Qt的QJsonObject和QJsonArray当做类变量来存储运行信息,发现这两货真的是巨坑.让人有一种JJ fly的感觉/(ㄒoㄒ)/~~. 写了个例子来说明下: MainWindow:: ...

  5. poj 1873 凸包+枚举

    The Fortified Forest Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 6198   Accepted: 1 ...

  6. poj 1113 凸包周长

    Wall Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 33888   Accepted: 11544 Descriptio ...

  7. better-scroll之吸顶效果巨坑挣扎中

    今天和大家分享下better-scroll这款移动端用来解决各种滚动需求的插件(目前已经支持PC) 关于其中的API大家可以去官网看下  这里就给大家介绍几种常用的以及需要注意的点是什么 首先说一下b ...

  8. (杭电 2054)A==B?(这真是个巨坑)

    A == B ? Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  9. SpriteKit在复制节点时留了一个巨坑给开发者,需要开发者手动把复制节点的isPaused设置为false

    根据When an overlay node with actions is copied there is currently a SpriteKit bug where the node’s is ...

随机推荐

  1. 【BZOJ 1878】 HH的项链

    [题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=1878 [算法] 显然,在线算法是不可做的,考虑离线算法 笔者的做法是莫队算法,时间复 ...

  2. Centos6.5添加Epel和Remi源安装Lamp环境

    想搭建一个Lamp环境,因为编译安装太麻烦,对于我这样的新手来说,太过于复杂.而CentOS自带的Apache.MySql和PHP的版本都太低,不想用.上百度搜了一轮,原来可以通过添加Epel和Rem ...

  3. Response.Redirect(),Server.Transfer(),Server.Execute()的区别与网站优化

    转 http://blog.csdn.net/dannywj1371/article/details/10213631 1.Response.Redirect():Response.Redirect方 ...

  4. SpringBoot(十) 异步任务,定时任务和邮件任务

    异步任务 “异步调用”对应的是“同步调用”,同步调用指程序按照定义顺序依次执行,每一行程序都必须等待上一行程序执行完成之后才能执行:异步调用指程序在顺序执行时,不等待异步调用的语句返回结果就执行后面的 ...

  5. 401 - Unauthorized: Access is denied due to invalid credentials.

    solution:change application pool from ApplicationPoolIdentity to NetworkService.

  6. here.less

    <html><head><title>Test Less</title><link rel="stylesheet/less" ...

  7. 深入分析C++虚函数表

    C++中的虚函数(Virtual Function)是用来实现动态多态性的,指的是当基类指针指向其派生类实例时,可以用基类指针调用派生类中的成员函数.如果基类指针指向不同的派生类,则它调用同一个函数就 ...

  8. libvirtd.service

    [root@kvm-server ~]# systemctl status libvirtd.service ● libvirtd.service - Virtualization daemon Lo ...

  9. 安装SSH、配置SSH无密码登录 ssh localhost

    集群.单节点模式都需要用到 SSH 登陆(类似于远程登陆,你可以登录某台 Linux 主机,并且在上面运行命令),Ubuntu 默认已安装了 SSH client,此外还需要安装 SSH server ...

  10. PHP下的异步尝试三:协程的PHP版thunkify自动执行器

    PHP下的异步尝试系列 如果你还不太了解PHP下的生成器和协程,你可以根据下面目录翻阅 PHP下的异步尝试一:初识生成器 PHP下的异步尝试二:初识协程 PHP下的异步尝试三:协程的PHP版thunk ...