POJ3268(Dijkstra_邻接矩阵)
https://vjudge.net/problem/POJ-3268
题目大意:
n个农场的n头奶牛将前往x农场,要选择一条来回时间最短的路径。
(一头牛的返回路线可能不同于她最初去派对的路线,因为道路是单向的。)
思路:
//有向图的迪杰斯特拉
如果以每头牛为起点遍历其到x的最短路,耗时太大。
有没有简便的方法呢?
如果,以x为起点,找到其余点的最短路,这求出的便是牛返回各自农场的最短路,
由于还要求牛前往x农场的最短路,
我们可以想到一个巧妙的方法:将所有的方向反向,再求一遍以x为起点,找到其余点的最短路。
所以就是在最短路的代码上加一个反向最短路。
#include<iostream>
#include<stdio.h>
#include<algorithm>
#include<string.h>
#define maxn 1005
#define inf 0x3f3f3f3f
using namespace std;
int cost[maxn][maxn],n,m,x;
int disback[maxn],discome[maxn];
bool vis[maxn];
int dij(int x)
{
int u,minn;
for(int i=;i<=n;i++)
{
disback[i]=cost[x][i];
discome[i]=cost[i][x];//将各边反转
}
for(int i=;i<n;i++)
{
u=-,minn=inf;
for(int j=;j<=n;j++)
{
if(!vis[j]&&disback[j]<minn)
{
u=j;
minn=disback[j];
}
}
//if(u=-1)return
vis[u]=;
for(int v=;v<=n;v++)
{
if(!vis[v]&&cost[u][v]!=inf)
{
if(disback[u]+cost[u][v]<disback[v])
disback[v]=disback[u]+cost[u][v];
}
}
}
memset(vis,,sizeof vis);
for(int i=;i<n;i++)
{
minn=inf,u=-;
for(int j=;j<=n;j++)
{
if(!vis[j]&&discome[j]<minn)
{
u=j;
minn=discome[j];
}
}
vis[u]=;
for(int j=;j<=n;j++)
{
if(!vis[j]&&cost[j][u]+discome[u]<discome[j])
discome[j]=cost[j][u]+discome[u];
}
}
minn=-;
for(int i=;i<=n;i++)
minn=max(minn,discome[i]+disback[i]);
return minn;
}
int main()
{
int i,a,b,c,j;
while(~scanf("%d%d%d",&n,&m,&x))
{
for(i=;i<=n;i++)
for(j=;j<=n;j++)
{
if(i!=j)
cost[i][j]=inf;
else
cost[i][j]=;
}
for(i=;i<m;i++)
{
scanf("%d%d%d",&a,&b,&c);
cost[a][b]=c;
}
printf("%d\n",dij(x));
}
return ;
}
POJ3268(Dijkstra_邻接矩阵)的更多相关文章
- HDU2544(dijkstra_邻接矩阵最水的题没有之一)
https://cn.vjudge.net/problem/HDU-2544 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shirt.但是每当我们的工作人员把上百件的衣服从商店运回到赛场 ...
- POJ-3268 Silver Cow Party---正向+反向Dijkstra
题目链接: https://vjudge.net/problem/POJ-3268 题目大意: 有编号为1-N的牛,它们之间存在一些单向的路径.给定一头牛的编号X,其他牛要去拜访它并且拜访完之后要返回 ...
- poj-3268最短路
title: poj-3268最短路 date: 2018-10-13 15:54:34 tags: acm 刷题 categories: ACM-最短路 概述 这是一道最短路的模板题,,,不过虽然是 ...
- 邻接矩阵的深度优先遍历(java版)
这是一个有向边带权的图 顶点数组:[v0, v1, v2, v3, v4] 边数组: v0 v1 v2 v3 v4 v0 6 v1 9 3 v2 2 5 v3 1 v4 package com.dat ...
- 数据结构-图-Java实现:有向图 图存储(邻接矩阵),最小生成树,广度深度遍历,图的连通性,最短路径1
import java.util.ArrayList; import java.util.List; // 模块E public class AdjMatrixGraph<E> { pro ...
- 邻接矩阵有向图(三)之 Java详解
前面分别介绍了邻接矩阵有向图的C和C++实现,本文通过Java实现邻接矩阵有向图. 目录 1. 邻接矩阵有向图的介绍 2. 邻接矩阵有向图的代码说明 3. 邻接矩阵有向图的完整源码 转载请注明出处:h ...
- 邻接矩阵有向图(二)之 C++详解
本章是通过C++实现邻接矩阵有向图. 目录 1. 邻接矩阵有向图的介绍 2. 邻接矩阵有向图的代码说明 3. 邻接矩阵有向图的完整源码 转载请注明出处:http://www.cnblogs.com/s ...
- 邻接矩阵有向图(一)之 C语言详解
本章介绍邻接矩阵有向图.在"图的理论基础"中已经对图进行了理论介绍,这里就不再对图的概念进行重复说明了.和以往一样,本文会先给出C语言的实现:后续再分别给出C++和Java版本的实 ...
- 邻接矩阵无向图(三)之 Java详解
前面分别介绍了邻接矩阵无向图的C和C++实现,本文通过Java实现邻接矩阵无向图. 目录 1. 邻接矩阵无向图的介绍 2. 邻接矩阵无向图的代码说明 3. 邻接矩阵无向图的完整源码 转载请注明出处:h ...
随机推荐
- python学习之老男孩python全栈第九期_数据库day001知识点总结 —— MySQL操作数据库以及数据表、基本数据类型、基本增删改查、外键定义以及创建
一. 学习SQL语句规则以及外键 1. 操作文件夹 create database db2; 创建文件夹 create database db2 default charset utf8; 创建文件夹 ...
- [转]Shared——探究react-native通信机制
原文:https://www.cnblogs.com/android-blogs/p/5623481.html 探究react-native通信机制 通信方式 我们所说的[通信],指的是RN中Java ...
- BZOJ1660: [Usaco2006 Nov]Bad Hair Day 乱发节(单调栈)
题意 题目链接 Sol 单调栈板子题.. 找到向左第一个比他大的位置,然后判断一下就可以了 #include<bits/stdc++.h> //#define int long long ...
- egg.js-基于koa2的node.js入门
一.Egg.JS 简介 Egg.JS是阿里开发的一套node.JS的框架,主要以下几个特点: Egg 的插件机制有很高的可扩展性,一个插件只做一件事,Egg 通过框架聚合这些插件,并根据自己的业务场景 ...
- CSS属性display的浅略探讨
display 的属性值有:none|inline|block|inline-block|list-item|run-in|table|inline-table|table-row-group|tab ...
- ubuntu命令行编译opencv c++项目
ubuntu终端编译opencv c++项目: g++ test.cpp `pkg-config opencv --libs --cflags opencv` -o test
- 使用IntelliJ IDEA配置Erlang开发环境
这篇文章比较详细,感谢作者,拷贝过来做个记录 ————————————————————————————————————————————————————————————————————————————— ...
- 大数据量报表APPLET打印分页传输方案
1 . 问题概述 当报表运算完成时,客户端经常需要调用润乾自带的runqianReport4Applet.jar来完成打印操作, 然而数据量比较大的时候,会导致无法加载完成,直至applet内存 ...
- Android控件显示和隐藏
Android控件都有visibility属性,该属性有三个可能值:visible.invisible.gone.可以通过预设或是Java程序控制这些控件的显示或隐藏. 一.在XML配置文件设置 可见 ...
- maven打包 springBoot 工程时,默认识别resources目录,习惯使用 resource 目录的需要手动指定静态资源目录
最近项目开发,发现springBoot项目在使用maven打包时,我们静态资源文件都放在resource目录下面,大致如下: 在使用maven打包时,发现静态资源没有打进去.原来springBoot默 ...