思路:这个题在秦皇岛的时候好像没有写出来,反正我是没有写出来,题解是听懂了;把直线和圆都看做一个结点,圆和直线用点到直线的距离与半径差求出来,圆和圆之间用点和点之间的距离和半径差表示,最后最短路跑一遍就行了。

#include<cstdio>
#include<vector>
#include<cmath>
#include<cstring>
#include<iostream>
#include<algorithm>
#define ll long long
#define inf 0x3f3f3f3f
using namespace std;
int vis[];
double mlen[];
const double maxn = 1e9 + ;
double map[][];
int n, a, b, c1, c2;
struct Node{
int x, y, r;
Node(){}
Node(int _x, int _y, int _r) :x(_x), y(_y), r(_r){}
}ya[]; void dijkstra(){
memset(vis, , sizeof vis); for (int i = ; i <= n + ; i++)
mlen[i] = map[][i];
mlen[] = ;
/*for (int i = 0; i <= n + 1; i++)
cout << mlen[i] << " * ";
*/
for (int t = ; t <= n + ; t++){
double ma = maxn; int p;
for (int i = ; i <= n + ; i++){
if (mlen[i] <= ma&&!vis[i]){ ma = mlen[i]; p = i; }
}
vis[p] = ;
//cout << mlen[p] << " " << p << endl;
for (int i = ; i <= n + ; i++){
if (p != i&&!vis[i] && mlen[p] + map[p][i] < mlen[i]){
mlen[i] = mlen[p] + map[p][i];
//cout << p << " " << i << " " << mlen[i] << endl;
}
}
}
}
int main(){ //memset(map, maxn, sizeof map); vector<Node>vec; scanf("%d%d%d%d%d", &n, &a, &b, &c1, &c2); map[][n + ] = map[n + ][] = abs(c1 - c2)*1.0 / sqrt(a*a + b*b);
for (int i = ; i <= n + ; i++)
for (int j = ; j <= n + ; j++)
map[i][j] = maxn; int x, y, r;
for (int i = ; i <= n; i++){
scanf("%d%d%d", &x, &y, &r);
vec.push_back(Node(x, y, r));
} for (int i = ; i < vec.size(); i++){
double len = abs(a*vec[i].x + b*vec[i].y + c1)*1.0 / sqrt(a*a + b*b) - vec[i].r*1.0;
if (len < )len = ;
map[][i + ] = len;
map[i + ][] = len;
}
for (int i = ; i < vec.size(); i++){
double len = abs(a*vec[i].x + b*vec[i].y + c2)*1.0 / sqrt(a*a + b*b) - vec[i].r*1.0;
if (len < )len = ;
map[n+][i + ] = len;
map[i + ][n+] = len;
} for (int i = ; i < n; i++){
for (int j = i + ; j < n; j++){
double len = sqrt(pow(vec[i].x - vec[j].x, ) + pow(vec[i].y - vec[j].y, ));
len = len - vec[i].r - vec[j].r;
if (len < )len = ;
map[i + ][j + ] = len;
map[j + ][i + ] = len;
}
}
/*for (int i = 0; i <= n + 1; i++){
for (int j = 0; j <= n + 1; j++)
cout << map[i][j] << " ";
cout << endl;
}*/
dijkstra();
printf("%.6lf\n", mlen[n + ]); return ;
}

牛客网补题 New Game!(原Wannafly summer camp day2原题)的更多相关文章

  1. 牛客网暑期ACM多校训练营(第九场) A题 FWT

    链接:https://www.nowcoder.com/acm/contest/147/A来源:牛客网 Niuniu has recently learned how to use Gaussian ...

  2. 牛客网Java刷题知识点之为什么HashMap不支持线程的同步,不是线程安全的?如何实现HashMap的同步?

    不多说,直接上干货! 这篇我是从整体出发去写的. 牛客网Java刷题知识点之Java 集合框架的构成.集合框架中的迭代器Iterator.集合框架中的集合接口Collection(List和Set). ...

  3. 牛客网Java刷题知识点之Map的两种取值方式keySet和entrySet、HashMap 、Hashtable、TreeMap、LinkedHashMap、ConcurrentHashMap 、WeakHashMap

    不多说,直接上干货! 这篇我是从整体出发去写的. 牛客网Java刷题知识点之Java 集合框架的构成.集合框架中的迭代器Iterator.集合框架中的集合接口Collection(List和Set). ...

  4. 牛客网 2018年东北农业大学春季校赛 L题 wyh的天鹅

    链接:https://www.nowcoder.com/acm/contest/93/L来源:牛客网 时间限制:C/C++ 3秒,其他语言6秒空间限制:C/C++ 262144K,其他语言524288 ...

  5. 牛客网 Java 工程师能力评估 20 题 - 详解

    牛客网 Java 工程师能力评估 20 题 - 详解 不知在看博客的你是否知道 牛客网,不知道就太落后了,分享给你 : 牛客网 此 20 题,绝对不只是 20 题! 免责声明:本博客为学习笔记,如有侵 ...

  6. 牛客网-湘潭大学校赛重现H题 (线段树 染色问题)

    链接:https://www.nowcoder.com/acm/contest/105/H来源:牛客网 n个桶按顺序排列,我们用1~n给桶标号.有两种操作: 1 l r c 区间[l,r]中的每个桶中 ...

  7. 牛客网 桂林电子科技大学第三届ACM程序设计竞赛 A.串串-后缀自动机模板题

    链接:https://ac.nowcoder.com/acm/contest/558/A来源:牛客网 A.串串 小猫在研究字符串. 小猫在研究字串. 给定一个长度为N的字符串S,问所有它的子串Sl…r ...

  8. 牛客网刷题(纯java题型 31~60题)

    牛客网刷题(纯java题型 31~60题) 重写Override应该满足"三同一大一小"三同:方法名相同,参数列表相同,返回值相同或者子类的返回值是父类的子类(这一点是经过验证的) ...

  9. 牛客网刷题(纯java题型 1~30题)

    牛客网刷题(纯java题型 1~30题) 应该是先extend,然后implement class test extends A implements B { public static void m ...

随机推荐

  1. OKEX websocket API 连接Python范例

    因为 websocket-client 新版的各种大脑降级设计 很多功能无法使用需要安装老版本websocket-client的包才能正常使用 pip3 install websocket-clien ...

  2. icons使用

    1.将选中图标加入项目 2.unicode方式查看连接在线连接 3.复制代码到样式表 4.引用样式,并设置I标签,颜色和大小可以通过设置i标签color和font-size进行调整 <i cla ...

  3. SQL 初级教程学习(六)

    1.创建视图 CREATE VIEW [Current Product List] ASSELECT ProductID,ProductNameFROM ProductsWHERE Discontin ...

  4. [POI2012]Vouchers

    Description 考虑正整数集合,现在有n组人依次来取数,假设第i组来了x人,他们每个取的数一定是x的倍数,并且是还剩下的最小的x个. 正整数中有m个数被标成了幸运数,问有哪些人取到了幸运数. ...

  5. 暴力 ZOJ 1403 Safecracker

    题目传送门 /* 暴力:纯暴力,在家水水 */ #include <cstdio> #include <cstring> #include <algorithm> ...

  6. taskkill帮助信息

    taskkill帮助信息: C:\Users\xusweeter>taskkill /? TASKKILL [/S system [/U username [/P [password]]]] { ...

  7. 转如何升级oracle版本?(11.2.0.1至11.2.0.4)

    dbua from 11.2,0.2 to 11.2.0.4 need 2hours 升级结果: 步骤名             日志文件名       状态 升级前操作   PreUpgrade.l ...

  8. SpringCloud+MyBatis+Redis整合—— 超详细实例(二)

    2.SpringCloud+MyBatis+Redis redis①是一种nosql数据库,以键值对<key,value>的形式存储数据,其速度相比于MySQL之类的数据库,相当于内存读写 ...

  9. 启动Windows PowerShell ISE

    Windows Server 2008 R2 环境下,启动PoserShell ISE方法: 方法1:在cmd.exe控制台或运行框中,输入 powershell_ise.exe 执行即可. 方法2: ...

  10. 维控PLC与电流变送器modbus通讯获取电流变送器数据

    2018-09-2319:28:01 今天本来要用单片机来做这个项目的,但是失败了.... 所以我又拿出了PLC来搞,也是相当之复杂,查了很多资料终于做出而来了. 今天还有事,赶紧临时备份总结一波