POJ2253 蛙跳 图论(Dijkstra变形)
来源:互联网 发布:李华清经济学考研知乎 编辑:程序博客网 时间:2024/04/30 17:13
好的吧吃了顿饭回来接着干Dijkstra。这回这道题稍微变形了一下。
做完这道题感觉嗯..dijkstra只是一种遍历方式,根据特定的松弛条件来遍历整个图。
题目概述:
嗯题目描述了两只青蛙,然后第一只青蛙想要努力跳到第二只青蛙那里去,位置是按坐标给的。然后中间可能有一些中介的石头,然后我们要计算的是,为使青蛙跳到目的地,其所需要的跳跃距离的最小值。
具体输入条件以及题目描述移步:
http://poj.org/problem?id=2253
算法思想:
主要还是拿dijkstra遍历吧。然后更新条件略有不同,主要是在移动之后,要计算min(当前距离,max(之前的跳跃点需要的距离,之前跳跃点和该点距离))
拿每一块石头当图的一个结点,结点之间必有边。边只有一个性质就是长度,从这个角度来说还是很trivial的。
实际上就是改这一个条件,然后写一个基本的dijkstra就好了。
代码部分:
#include <iostream>#include <iomanip>#include <cmath>#include <string.h>#include <algorithm>struct point{int x, y;};point poi[202];double d[202];double w[202][202]; bool v[202];using namespace std;int n;double INF = 100000000.0;double dis(int ax,int ay, int bx, int by) {return sqrt((ax - bx)*(ax - bx) + (ay - by)*(ay - by));}double dijkstra() {memset(v, 0, sizeof(v));for (int i = 2; i <= n; i++){d[i] = INF;}d[1] = 0; for (int i = 1; i <= n; i++){double m = INF; int x = 1;for (int j = 1; j <= n; j++){if (!v[j] && d[j] < m) {m = d[j];x = j;}}v[x] = 1;for (int j = 1; j <= n; j++){d[j] = min(d[j], max(d[x], w[x][j]));//cout << "here d[" << j << "] is " << d[j] << endl;}}return d[n];}int main() {int t = 1;while (cin >> n && n != 0) {int sx, sy, ex, ey;cin >> sx >> sy >> ex >> ey;if (n == 2) {cout << "Scenario #" << t << endl;cout << "Frog Distance = " << fixed << setprecision(3) << sqrt((sx - ex)*(sx - ex) + (sy - ey)*(sy - ey)) << endl;cout << endl;t++;continue;}poi[1].x = sx; poi[1].y = sy;poi[n].x = ex; poi[n].y = ey;for (int i = 2; i < n; i++){int tmp_x, tmp_y;cin >> tmp_x >> tmp_y;poi[i].x = tmp_x;poi[i].y = tmp_y;}for (int i = 1; i <= n; i++){for (int j = 1; j <= n; j++){w[i][j] = dis(poi[i].x, poi[i].y, poi[j].x, poi[j].y);}}cout << "Scenario #" << t << endl;cout << "Frog Distance = " << fixed << setprecision(3) << dijkstra() << endl;cout << endl;t++;}return 0;}
0 0
- POJ2253 蛙跳 图论(Dijkstra变形)
- poj2253 Dijkstra变形
- 最短路径(3)--poj2253(Dijkstra变形题)
- POJ2253 Frogger(最短路变形,floyd,Dijkstra,spfa)
- poj2253--dijkstra
- poj2253 Dijkstra
- poj2253 floyd变形
- poj2253 变形Floyd
- poj2253 dijsktra变形
- Frogger(poj2253)-floyd变形
- poj2253---dijkstra算法妙用
- POJ2253 Frogger 【Dijkstra】
- POJ2253 Frogger Dijkstra & Floyd
- poj2253(dijkstra||dijkstra||floy…
- 蛙跳
- poj2253 Frogger(最短路变形)
- 【POJ2253】【Frogger】【dij变形题】
- POJ2253 最短路径变形
- Unity中3D模型动画的基础用法
- PAT 02-2. 一元多项式求导 (25)
- 第五章 知识结构导图
- 修改opencv源码的方法
- 04-2. File Transfer (25)并查集
- POJ2253 蛙跳 图论(Dijkstra变形)
- hdu_1874_畅通工程_最短路_dijkstra
- Halcon程序
- 第六章 知识结构导图
- linux下python安装pylib
- QML与C++混合编程详解
- 数据库的基本操作
- Windows下时间测试函数
- MFC ODBC数据库操作编程