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

#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. c语言程序设计案例教程(第2版)笔记(六)—字符串处理实例

    字符串处理 功能描述:从键盘输入一个文本行后,为用户提供菜单选择,实现字符串一些操作——显示文本行.查找并替换指定子串.删除指定子串.统计指定子串数目. 实现代码: #include<stdio ...

  2. python列表和元组的常用操作

    一.列表 需要安利一下:列表和字符串数是不一样的.进行操作时列表可以发生改变,而字符串不可以,所以直接在原来的对象上操作. 1.列表的增加 def append(self, p_object): # ...

  3. 438 Find All Anagrams in a String 找出字符串中所有的变位词

    详见:https://leetcode.com/problems/find-all-anagrams-in-a-string/description/ C++: class Solution { pu ...

  4. APP多渠道打包

    多渠道打包的概念: 打包是指使用证书文件对app签名生成一个apk文件. 多渠道打包指的就是我们的app在开发完成之后需要投放到不同的市场,比如说Google市场.百度市场等,为了统计应用在各个市场的 ...

  5. AJPFX关于Collection 集合的表述

    集合的遍历class Demo_Collection{     public static void main(String[] args){          Collection c = new ...

  6. HTML5应用缓存与Web Workers

    1.什么是应用程序缓存      HTML5引入了应用程序缓存,这意味着web应用可进行缓存,并可在没有因特网链接时进行访问. 2.应用缓存的优势      离线浏览   用户可在应用离线时使用它们 ...

  7. 行内元素对齐各种问题--从line-height和vertical-align的角度分析

    最近研究行内元素的对齐问题,发现img不管怎么设置,下边都有一块留白,强迫症无法忍受未知,于是开始了查阅探索之旅. 辗转来到张鑫旭的博客,他对行内盒子模型做了详细的介绍,包括“幽灵节点”,“line- ...

  8. 一段js实现复制文本内容到剪切板

    <script type="text/javascript"> function copyUrl2() { var Url2=document.getElementBy ...

  9. kalman滤波器公式的推导

    卡尔曼滤波的使用范围: 该系统要有如下关系: 计算步骤: PART0:INI PART1:Time update 迭代的目标:从X(K-1)+ 求得X(K) + 因此,先有X(K-1)+,已知F,G. ...

  10. 聊5块钱P2V

    上一秒还在写代码,下一秒就跑机房干活. 这台机器产制石器时代,重启一次后再就启动不了了.这个故障处理的方式我们以后再谈. 今天聊聊啥是P2V,国人总喜欢弄些稀奇古怪的定义来证明自己技术很牛X,就跟当年 ...