hdu1245 两个权值的最短路
题意:
求s到t的最短路,如果路径相同求那么要求另一个权值尽可能的小.
思路:
水题,就是spfa的比较那个地方多了一个可以更新的机会,当(s_x[xin] > s_x[tou] + E[k].cost || s_x[xin] == s_x[tou] + E[k].cost && s_t[xin] > s_t[tou] + 1) 时更新就行了..
#include<stdio.h> #include<string.h> #include<queue> #include<math.h>#define N_node 100 + 5 #define N_edge 20000 + 500 #define INF 1000000000 using namespace std;typedef struct {int to ,next;double cost; }STAR;typedef struct {double x ,y; }NODE;STAR E[N_edge]; NODE node[N_node]; int list[N_node] ,tot; double s_x[N_node]; int s_t[N_node];void add(int a ,int b ,double c) {E[++tot].to = b;E[tot].cost = c;E[tot].next = list[a];list[a] = tot; }double abss(double x) {return x > 0 ? x : -x; } double minn(double x ,double y) {return x < y ? x : y; }void SPFA(int s ,int n) {for(int i = 0 ;i <= n ;i ++)s_x[i] = INF ,s_t[i] = INF;int mark[N_node] = {0};mark[s] = 1;s_x[s] = s_t[s] = 0;queue<int>q;q.push(s);while(!q.empty()){int xin ,tou;tou = q.front();q.pop();mark[tou] = 0;for(int k = list[tou] ;k ;k = E[k].next){xin = E[k].to;if(s_x[xin] > s_x[tou] + E[k].cost || abss(s_x[xin] - s_x[tou] + E[k].cost) < 1e-6 && s_t[xin] > s_t[tou] + 1){s_x[xin] = s_x[tou] + E[k].cost;s_t[xin] = s_t[tou] + 1;if(!mark[xin]){mark[xin] = 1;q.push(xin);}}}}return ; }int main () {int n ,i ,j;double d;while(~scanf("%d %lf" ,&n ,&d)){for(i = 1 ;i <= n ;i ++)scanf("%lf %lf" ,&node[i].x ,&node[i].y);memset(list ,0 ,sizeof(list));tot = 1;for(i = 1 ;i <= n ;i ++)for(j = i + 1 ;j <= n ;j ++){double dis = pow(node[i].x - node[j].x ,2.0) + pow(node[i].y - node[j].y,2.0);if(dis <= d * d) {add(i ,j ,sqrt(dis));add(j ,i ,sqrt(dis));}}int s = 0 ,t = n + 1;for(i = 1 ;i <= n ;i ++){double dis = pow(node[i].x,2.0) + pow(node[i].y ,2.0);if(pow(d + 7.5 ,2.0) >= dis)add(s ,i ,sqrt(dis) - 7.5);dis = minn(50 - abss(node[i].x) ,50 - abss(node[i].y));if(dis <= d) add(i ,t ,dis);}if(d >= 50 - 7.5)add(s ,t ,50 - 7.5);SPFA(s ,t);if(s_x[t] == INF)printf("can't be saved\n");elseprintf("%.2lf %d\n" ,s_x[t] ,s_t[t]);}return 0; }
hdu1245 两个权值的最短路相关推荐
- PTA 7-3 旅游规划 (25分)(双权值Dijkstra最短路)
7-3 旅游规划 (25分) 有了一张自驾旅游路线图,你会知道城市间的高速公路长度.以及该公路要收取的过路费.现在需要你写一个程序,帮助前来咨询的游客找一条出发地和目的地之间的最短路径.如果有若干条路 ...
- 【POJ - 1724 】ROADS (带限制的最短路 或 dfs 或 A*算法,双权值)
题干: N cities named with numbers 1 ... N are connected with one-way roads. Each road has two paramete ...
- [NOIP2014]联合权值
NOIp2014提高组 [题目描述] 无向连通图G 有n 个点,n - 1 条边.点从1 到n 依次编号,编号为 i 的点的权值为W i ,每条边的长度均为1 .图上两点( u , v ) 的距 ...
- P1351 联合权值[鬼畜解法]
题目描述 无向连通图 G 有 n 个点,n−1 条边.点从 1 到 n 依次编号,编号为 i 的点的权值为 Wi,每条边的长度均为 1.图上两点 (u,v) 的距离定义为 u 点到 v 点的最短距离 ...
- 最短路计数「负权值」
最短路计数 题目描述: n个点m条边的无向无权图,问从顶点1开始,到其他每个点的最短路有几条 思路: 最短路计数首先要满足的条件是不能存在权值为0的环,如果存在,则能经过这个环的点的最短路的数量就是无 ...
- 【PAT - 甲级1003】Emergency (25分)(Dijkstra,最短路条数,双权值最短路)
题干: As an emergency rescue team leader of a city, you are given a special map of your country. The m ...
- 【ZOJ - 3946】Highway Project(最短路子图,维护双权值,贪心,最小树形图)
题干: Edward, the emperor of the Marjar Empire, wants to build some bidirectional highways so that he ...
- *【51nod - 1459】迷宫游戏(记录双向权值的Dijkstra单源最短路)
题干: 你来到一个迷宫前.该迷宫由若干个房间组成,每个房间都有一个得分,第一次进入这个房间,你就可以得到这个分数.还有若干双向道路连结这些房间,你沿着这些道路从一个房间走到另外一个房间需要一些时间.游 ...
- 【POJ - 2349】【UVA - 10369】 Arctic Network(最小生成树求权值第k大的边)(内附两种算法)
题干: The Department of National Defence (DND) wishes to connect several northern outposts by a wirele ...
最新文章
- PHP中htmlentities跟htmlspecialchars的区别
- corba的兴衰_数据科学薪酬的兴衰
- efm32芯片电压_解读GP21+EFM32低功耗热量表电路
- 智慧城市发展未来PSD分层海报模板|科技突破你的想象!
- C语言 pthread_exit
- 海康、大华等厂家监控摄像机rtsp地址格式
- html列自动变高,HTML 应用 多列浮动等高处理
- rrdtool安装编译提示错误:Can’t locate ExtUtils/MakeMaker.pm in @INC
- 【C++/Python 双语言实现】Luogu1196 银河英雄传说 + Python函数的定义与调用
- 提高WordPress访问速度的十种方法
- TPS_AOV_2 Algorithm made by Knuth {照TAOCP 2.2.3 完成}
- 64位windows10操作系统,如何使用32位的IE浏览器
- 硼替佐米大鼠血清白蛋白RSA纳米粒|布立尼布小麦麦清白蛋白纳米粒|马赛替尼豆清白蛋白纳米粒(齐岳)
- 在XX小学六一儿童节庆祝大会上的致辞
- Matplotlib风羽自定义
- TEST语言编译器--语法分析
- 神州笔记本电脑开机出现CMOS message【已解决】
- 大数据培训技术使用spark对phoenix的读写
- 630本经典绘本世界中英文PDF+音视频,呕心推荐史上最全电子版绘本合集
- ssm养老院信息管理系统毕业设计源码181550