title: poj-3268最短路

date: 2018-10-13 15:54:34

tags:

  • acm
  • 刷题

    categories:
  • ACM-最短路

概述

这是一道最短路的模板题,,,不过虽然是模板题,,,还是有一些细节的,,,,QAQ

刚开始我的思路是建立一个汇点,,,然后求这个点为起点到终点x的最短路,,,再求终点到汇点的最短路,,,最后找一个和最大的,,,,这么想是因为和之前做的一道题很像,,,但像归像,,,终究不一样的,,,,这样还是求不出最后的结果,,,因为即使求出汇点到终点的最短路,,,但并不是每个点到终点的最短路,,,QAQ

分析思路

首先确定是单元最短路有关的题,,,而且题目保证正边,,,所以选择dijkstra解决,,,

其次,,,我之前好像还是单源最短路的理解不够清楚,,,

单源最短路一个最主要的性质就是所选起点到任意一点的最短路都可以求出来

这道题分成两部分,,一部分是所有点到终点x的最短路,,,另一个是终点到所有点的最短路,,,

显然后一部分可以直接调用一次dijkstra便可以求出,,,

而前者可以考虑反方向,,,所有点到终点的最短路就相当于沿相同的最短路从 终点x 到 每个点 的最短路,,,这个相同的最短路就是指:假如1到3的最短路是1->4->3那么他就等同于3->4->1,,,所以再求前一部分就可以将图中的每一条路的方向都取反方向,,,也就是逆图,,,这样一终点x为起点到各点的最短路就等于各点到终点x的最短路,,,

所以为了实现逆图选择 邻接矩阵 要比其他方式的存图要好一些,,,

实现

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <queue>
#include <algorithm>
#include <cstring> using namespace std; const int maxn = 1e3 + 10;
//const int maxm = 1e5 + 10;
const int inf = 0x3f3f3f3f; int cost[maxn][maxn];
bool vis[maxn];
int dis1[maxn];
int dis2[maxn];
int cnt;
int n , m , x; void dijkstra(int n , int s , int dis[] , int cost[][maxn])
{
//init
for(int i = 1; i <= n; ++i)
dis[i] = (i == s) ? 0 : inf;
memset(vis , false , sizeof(vis)); for(int i = 0; i < n; ++i)
{
int k = -1;
int m = inf;
for(int j = 1; j <= n; ++j)
{
if(!vis[j] && dis[j] < m)
{
m = dis[j];
k = j;
}
}
if(k == -1) break;
vis[k] = true;
for(int j = 1; j <= n; ++j)
if(!vis[j] && dis[k] + cost[k][j] < dis[j])
dis[j] = dis[k] + cost[k][j];
}
} int main()
{
int u , v , w;
while(scanf("%d%d%d" , &n , &m , &x) != EOF)
{
for(int i = 1; i <= n; ++i)
for(int j = 1; j <= n; ++j)
{
if(i == j) cost[i][j] = 0;
else cost[i][j] = inf;
}
for(int i = 1; i <= m; ++i)
{
scanf("%d%d%d" , &u , &v , &w);
cost[u][v] = min(cost[u][v] , w);
}
dijkstra(n , x , dis1 , cost);
for(int i = 1; i <= n; ++i)
for(int j = 1; j < i; ++j)
swap(cost[i][j] , cost[j][i]);
dijkstra(n , x , dis2 , cost); int ans = 0;
for(int i = 1; i <= n; ++i)
ans = max(ans , dis1[i] + dis2[i]); printf("%d\n" , ans);
}
}

(end)

什么时候才能真正的感觉这才是水题啊,,,QAQ

poj-3268最短路的更多相关文章

  1. poj 3268 最短路dijkstra *

    题目大意:给出n个点和m条边,接着是m条边,代表从牛a到牛b需要花费c时间,现在所有牛要到牛x那里去参加聚会,并且所有牛参加聚会后还要回来,给你牛x,除了牛x之外的牛,他们都有一个参加聚会并且回来的最 ...

  2. POJ 3268 最短路应用

    POJ3268 题意很简单 正向图跑一遍SPFA 反向图再跑一边SPFA 找最大值即可. #include<iostream> #include<cstdio> #includ ...

  3. POJ 3268——Silver Cow Party——————【最短路、Dijkstra、反向建图】

    Silver Cow Party Time Limit:2000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u Su ...

  4. POJ 3268 Silver Cow Party 最短路—dijkstra算法的优化。

    POJ 3268 Silver Cow Party Description One cow from each of N farms (1 ≤ N ≤ 1000) conveniently numbe ...

  5. DIjkstra(反向边) POJ 3268 Silver Cow Party || POJ 1511 Invitation Cards

    题目传送门 1 2 题意:有向图,所有点先走到x点,在从x点返回,问其中最大的某点最短路程 分析:对图正反都跑一次最短路,开两个数组记录x到其余点的距离,这样就能求出来的最短路以及回去的最短路. PO ...

  6. POJ 3268 Silver Cow Party (最短路径)

    POJ 3268 Silver Cow Party (最短路径) Description One cow from each of N farms (1 ≤ N ≤ 1000) convenientl ...

  7. Heavy Transportation POJ 1797 最短路变形

    Heavy Transportation POJ 1797 最短路变形 题意 原题链接 题意大体就是说在一个地图上,有n个城市,编号从1 2 3 ... n,m条路,每条路都有相应的承重能力,然后让你 ...

  8. POJ 3268 Silver Cow Party 最短路

    原题链接:http://poj.org/problem?id=3268 Silver Cow Party Time Limit: 2000MS   Memory Limit: 65536K Total ...

  9. poj - 3268 Silver Cow Party (求给定两点之间的最短路)

    http://poj.org/problem?id=3268 每头牛都要去标号为X的农场参加一个party,农场总共有N个(标号为1-n),总共有M单向路联通,每头牛参加完party之后需要返回自己的 ...

  10. poj 3268 Silver Cow Party(最短路,正反两次,这个模版好)

    题目 Dijkstra,正反两次最短路,求两次和最大的. #define _CRT_SECURE_NO_WARNINGS //这是找出最短路加最短路中最长的来回程 //也就是正反两次最短路相加找最大的 ...

随机推荐

  1. 网摘关于BarCodeControl控件

    简介 BarCodeControl是一个用户制作条形码的控件. MicrosoftBarcodeControl9.0是可以在MicrosoftOfficeAccess窗体和报表中显示条码符号的Acti ...

  2. 2017 ACM-ICPC 亚洲区(南宁赛区)网络赛:Frequent Subsets Problem (状态压缩)

    题目链接 题目翻译: 给出一个数n,和一个浮点数a,数n代表全集U = {1,2,...,n},然后给出 M个U的子集,如果一个集合B(是U的子集),M个集合中有至少M*a个集合包含B, 则B这个集合 ...

  3. UNIX网络编程 第5章 TCP客户/服务器程序示例

    UNIX网络编程 第5章 TCP客户/服务器程序示例

  4. Electron build 无法下载 winCodeSign 等资源

    将 7z 文件下载到 以下 cache 目录并解压 macOS: ~/Library/Caches/electron-builder Linux: ~/.cache/electron-builder ...

  5. 【Nginx】 Nginx实现端口转发

    什么是端口转发 当我们在服务器上搭建一个图书以及一个电影的应用,其中图书应用启动了 8001 端口,电影应用启动了 8002 端口.此时如果我们可以通过 localhost:8001 //图书 loc ...

  6. 【杂谈】需要mark的一些东西

    https://riteme.github.io/blog/2017-10-28/oi-coding-guidelines.html https://www.luogu.org/blog/34238/ ...

  7. spin_lock & mutex_lock的区别? 【转】

    转自:http://blog.csdn.net/wilsonboliu/article/details/19190861 本文由该问题引入到内核锁的讨论,归纳如下   为什么需要内核锁? 多核处理器下 ...

  8. mysql备份的 三种方式【转】

    备份的本质就是将数据集另存一个副本,但是原数据会不停的发生变化,所以利用备份只能回复到数据变化之前的数据.那变化之后的呢?所以制定一个好的备份策略很重要. 一.备份的目的 做灾难恢复:对损坏的数据进行 ...

  9. Nginx常见错误与问题之解决方法技术指南

      Nginx常见错误与问题之解决方法技术指南. 安装环境: 系统环境:redhat enterprise 6.5 64bit 1.Nginx 常见启动错误 有的时候初次安装nginx的时候会报这样的 ...

  10. mycat读写分离与主从切换【转】

    什么是mycat,以及mycat的优点和特性本文不做赘述,本文继续本着实战的态度,来分享一些个人对mycat的基础功能实践.本文mycat的读写分离和主从切换的环境为mysql主从环境. 如何安装my ...