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

#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. 全排列(传统&&黑科技)

    近期几次考试的一些题目暴力分都有用到全排列. 全排列是个好东西啊... 回想一下,我们最开始学到全排列是什么时候呢? 大概是学搜索的时候罢... 一.传统搜索算法 想复习可以戳 https://www ...

  2. 作为一个程序员,你了解 win 上有哪些必装的软件吗

    关于 win 的一些基础必知内容之前已经分享过,没有看过的可以戳此处→Windows 使用之那些你还不知道操作 新系统安装的第一个软件 Google Chrome 毫无疑问,作为程序员应该是首选的浏览 ...

  3. Python unittest 基本框架解析(2)

    下面例子,是一般测试框架的基本结构 框架知识点包括:实例化被测试模块类.装载测试用例.测试套件打包.保存测试输出结果.生成测试报告等 测试情况包括   :跳过某个case.执行成功.执行失败 #待测试 ...

  4. python版本2和3使用range()函数方法

    python 2:可以直接使用range(5) 输入的列表结果和预期的一样 python 3:使用range(5) 得到列表结果却是这个,和预期的不一致,其原因是节省空间,防止过大的列表产生 如果想要 ...

  5. 里氏替换原则中is和as分别的作用

    is 是用于检查对象是否指定类型兼容 if(empls[i] is SE){ ((SE)empls).SayHi(); } as 不用强转可以直接转换 if(empls[i] is SE){ SE s ...

  6. JAVA300集笔记

    章节2 java入门阶段 2.1注释 单行注释 //  多行注释 /* 内容*/ 文本注释/**内容*/ 注释是为了方便阅读代码,在编译时注释会被删除. 2.2 标识符 标识符作用: 标识符用来给变量 ...

  7. php接收json格式数据(text/xml)

    在API服务中,目前流行采用json形式来交互. 给前端调用的接口输出Json数据,这个比较简单,只需要组织好数据,用json_encode($array) 转化一下,前端就得到json格式的数据. ...

  8. VS2010 好用的javascript扩展工具

    工具1) JScript Editor Extensions 折叠代码 下载地址: JScript Editor Extensions 工具2) Javascript parser 以树形方式查的代码 ...

  9. JAVA 学习笔记 - 反射机制

    1.   JAVA反射机制的概念 2. 怎样实例化一个 Class对象 Class.forName(包名.类名); 对象.getClass(); 类.class; ================== ...

  10. Codeforces_791_B. Bear and Friendship Condition_(dfs)

    B. Bear and Friendship Condition time limit per test 1 second memory limit per test 256 megabytes in ...