题意:给定n个点的坐标,问从第一个点到第二个点的最小跳跃范围。d(i)表示从第一个点到达第i个点的最小跳跃范围.

AC代码

  1. #include <cstdio>
  2. #include <cmath>
  3. #include <cctype>
  4. #include <algorithm>
  5. #include <cstring>
  6. #include <utility>
  7. #include <string>
  8. #include <iostream>
  9. #include <map>
  10. #include <set>
  11. #include <vector>
  12. #include <queue>
  13. #include <stack>
  14. using namespace std;
  15. #pragma comment(linker, "/STACK:1024000000,1024000000")
  16. #define eps 1e-10
  17. #define inf 0x3f3f3f3f
  18. #define PI pair<int, int>
  19. typedef long long LL;
  20. const int maxn = 200 + 5;
  21. int d[maxn], vis[maxn];
  22.  
  23. struct node{
  24. int x, y;
  25. }a[maxn];
  26.  
  27. struct HeapNode{
  28. int d, u;
  29. HeapNode() {}
  30. HeapNode(int d, int u):d(d), u(u) {}
  31. bool operator < (const HeapNode &p) const {
  32. return d > p.d;
  33. }
  34. };
  35.  
  36. void dijkstra(int s, int n) {
  37. priority_queue<HeapNode>q;
  38. memset(d, inf, sizeof(d));
  39. d[0] = 0;
  40. memset(vis, 0, sizeof(vis));
  41. q.push(HeapNode(0, 0));
  42. while(!q.empty()) {
  43. HeapNode p = q.top(); q.pop();
  44. int u = p.u;
  45. if(vis[u]) continue;
  46. vis[u] = 1;
  47. for(int i = 0; i < n; ++i) {
  48. if(u == i) continue;
  49. int dis = (a[u].x - a[i].x)*(a[u].x - a[i].x) + (a[u].y - a[i].y)*(a[u].y - a[i].y);
  50. dis = max(dis, d[u]);
  51. if(d[i] > dis) {
  52. d[i] = dis;
  53. q.push(HeapNode(d[i], i));
  54. }
  55. }
  56. }
  57. }
  58.  
  59. int main() {
  60. int n, kase = 1;
  61. while(scanf("%d", &n) == 1 && n) {
  62. for(int i = 0; i < n; ++i) scanf("%d%d", &a[i].x, &a[i].y);
  63. dijkstra(0, n);
  64. printf("Scenario #%d\n", kase++);
  65. printf("Frog Distance = %.3f\n\n", sqrt((double)d[1]));
  66. }
  67. return 0;
  68. }

如有不当之处欢迎指出!

POJ - 2253 Frogger 单源最短路的更多相关文章

  1. POJ 2253 Frogger(dijkstra 最短路

    POJ 2253 Frogger Freddy Frog is sitting on a stone in the middle of a lake. Suddenly he notices Fion ...

  2. poj 2253 Frogger (dijkstra最短路)

    题目链接:http://poj.org/problem?id=2253 Frogger Time Limit: 1000MS   Memory Limit: 65536K Total Submissi ...

  3. POJ 2253 - Frogger - [dijkstra求最短路]

    Time Limit: 1000MS Memory Limit: 65536K Description Freddy Frog is sitting on a stone in the middle ...

  4. 最短路(Floyd_Warshall) POJ 2253 Frogger

    题目传送门 /* 最短路:Floyd算法模板题 */ #include <cstdio> #include <iostream> #include <algorithm& ...

  5. POJ 2253 Frogger ,poj3660Cow Contest(判断绝对顺序)(最短路,floyed)

    POJ 2253 Frogger题目意思就是求所有路径中最大路径中的最小值. #include<iostream> #include<cstdio> #include<s ...

  6. POJ. 2253 Frogger (Dijkstra )

    POJ. 2253 Frogger (Dijkstra ) 题意分析 首先给出n个点的坐标,其中第一个点的坐标为青蛙1的坐标,第二个点的坐标为青蛙2的坐标.给出的n个点,两两双向互通,求出由1到2可行 ...

  7. 最短路模板(Dijkstra & Dijkstra算法+堆优化 & bellman_ford & 单源最短路SPFA)

    关于几个的区别和联系:http://www.cnblogs.com/zswbky/p/5432353.html d.每组的第一行是三个整数T,S和D,表示有T条路,和草儿家相邻的城市的有S个(草儿家到 ...

  8. [ACM_图论] Domino Effect (POJ1135 Dijkstra算法 SSSP 单源最短路算法 中等 模板)

    Description Did you know that you can use domino bones for other things besides playing Dominoes? Ta ...

  9. 用scheme语言实现SPFA算法(单源最短路)

    最近自己陷入了很长时间的学习和思考之中,突然发现好久没有更新博文了,于是便想更新一篇. 这篇文章是我之前程序设计语言课作业中一段代码,用scheme语言实现单源最段路算法.当时的我,花了一整天时间,学 ...

随机推荐

  1. Long转Date/页面自定义标签

    运行时发现异常:org.apache.jasper.JasperException: javax.el.ELException: java.lang.IllegalArgumentException: ...

  2. k8s 如何 Failover?- 每天5分钟玩转 Docker 容器技术(127)

    上一节我们有 3 个 nginx 副本分别运行在 k8s-node1 和 k8s-node2 上.现在模拟 k8s-node2 故障,关闭该节点. 等待一段时间,Kubernetes 会检查到 k8s ...

  3. 计算机改名引发的ORA

    近期上班时,由于开机时老是提示" 局域网出现计算机重名冲突",于是把计算机名字给改了,从PC2010081312zeo改为了CXBIKKKKKKK,结果第二天来的时候,用PL/SQ ...

  4. mybatis 中文文档

    http://www.mybatis.org/mybatis-3/zh/sqlmap-xml.html

  5. sublime卡顿

    sublime突然卡顿,输入字符要一两秒后才显示出来, 解决方法:首选项--插件控制--禁用插件 Git Gutter

  6. 一行代码搭建 Python 静态服务器

    如果电脑上安装有Python, 那么进入到目标文件夹,在终端中运行如下命令, 即可搭建映射当前目录的静态文件服务器: python -m SimpleHTTPServer 9000 默认端口号是800 ...

  7. Ajax异步信息抓取方式

    淘女郎模特信息抓取教程 源码地址: cnsimo/mmtao 网址:https://0x9.me/xrh6z   判断一个页面是不是Ajax加载的方法: 查看网页源代码,查找网页中加载的数据信息,如果 ...

  8. Vue.js根据列表某列值更新filter

    <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...

  9. python小练习(自己瞎倒腾)

    python小练习 在网上无意中看到一个问题,心血来潮写了写,觉得比较有意思,以后遇到这种有意思的小练习也记录下. #!/usr/bin/env python # -*- coding:utf-8 - ...

  10. BZOJ 3512: DZY Loves Math IV [杜教筛]

    3512: DZY Loves Math IV 题意:求\(\sum_{i=1}^n \sum_{j=1}^m \varphi(ij)\),\(n \le 10^5, m \le 10^9\) n较小 ...