点我看题目

题意 :中文不详述。

思路 :因为这个题加了一个要求就是路径数目得是x的倍数。所以在原来算法的一维dis数组增加到二维,用来存走的路径数%x。也可以用spfa做。

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <iostream> using namespace std ; #define LL long long
const int maxn = ;
const int maxm = ;
bool vis[maxn][maxn] ;
const LL INF = 1LL<< ;
int cnt = ;
int head[maxn] ;
LL dist[maxn][maxn] ;
int n , m ; struct node
{
int u,v,w ;
int next ;
}Edge[maxm] ; void addedge(int u,int v,int w)
{
Edge[cnt].u = u ;
Edge[cnt].v = v ;
Edge[cnt].w = w ;
Edge[cnt].next = head[u] ;
head[u] = cnt++ ;
} LL dijkstra(int s,int t,int x)
{
for(int i = ; i < n ; i++)
for(int j = ; j < x ; j++)
{
dist[i][j] = INF ;
vis[i][j] = false ;
}
dist[s][] = ;
while(true)
{
LL minn = INF ;
int u = - ;
int flag , xx ;
for(int i = ; i < n ; i++)
{
for(int j = ; j < x ; j++)
{
if(!vis[i][j] && minn > dist[i][j])
{
minn = dist[i][j] ;
u = i ;
flag = j ;
xx = (flag+)%x ;
}
}
}
if(u == -) return - ;
vis[u][flag] = true ;
if(vis[t][]) return dist[t][] ;
for(int j = head[u] ; j != - ; j = Edge[j].next)
{
int v = Edge[j].v ;
if(!vis[v][xx] && minn + Edge[j].w < dist[v][xx])
dist[v][xx] = minn + Edge[j].w ;
}
}
}
int main()
{
int T,s,t,x ;
scanf("%d",&T) ;
while(T--)
{
cnt = ;
memset(head,-,sizeof(head)) ;
// memset(vis,false,sizeof(vis) ) ;
scanf("%d %d",&n,&m) ;
int u,v, w ;
for(int i = ; i < m ; i++)
{
scanf("%d %d %d",&u,&v,&w) ;
addedge(u,v,w) ;
}
scanf("%d %d %d",&s,&t,&x) ;
LL ans = dijkstra(s,t,x) ;
if(ans != -)
printf("%lld\n",dist[t][]) ;
else printf("No Answer!\n") ;
}
return ;
}

SDUT 2622 最短路径(Dijkstra)的更多相关文章

  1. 最短路径 dijkstra

    最短路径 dijkstra #include <stdio.h> #include <string.h> #include <limits.h> #define M ...

  2. 网络最短路径Dijkstra算法

    最近在学习算法,看到有人写过的这样一个算法,我决定摘抄过来作为我的学习笔记: <span style="font-size:18px;">/* * File: shor ...

  3. c/c++ 图的最短路径 Dijkstra(迪杰斯特拉)算法

    c/c++ 图的最短路径 Dijkstra(迪杰斯特拉)算法 图的最短路径的概念: 一位旅客要从城市A到城市B,他希望选择一条途中中转次数最少的路线.假设途中每一站都需要换车,则这个问题反映到图上就是 ...

  4. 单源最短路径Dijkstra算法,多源最短路径Floyd算法

    1.单源最短路径 (1)无权图的单源最短路径 /*无权单源最短路径*/ void UnWeighted(LGraph Graph, Vertex S) { std::queue<Vertex&g ...

  5. 最短路径——Dijkstra算法和Floyd算法

    Dijkstra算法概述 Dijkstra算法是由荷兰计算机科学家狄克斯特拉(Dijkstra)于1959 年提出的,因此又叫狄克斯特拉算法.是从一个顶点到其余各顶点的最短路径算法,解决的是有向图(无 ...

  6. 最短路径-Dijkstra算法与Floyd算法

    一.最短路径 ①在非网图中,最短路径是指两顶点之间经历的边数最少的路径. AE:1    ADE:2   ADCE:3   ABCE:3 ②在网图中,最短路径是指两顶点之间经历的边上权值之和最短的路径 ...

  7. 数据结构实验之图论七:驴友计划 ( 最短路径 Dijkstra 算法 )

    数据结构实验之图论七:驴友计划 Time Limit: 1000 ms           Memory Limit: 65536 KiB Submit Statistic Discuss Probl ...

  8. 最短路径——Dijkstra算法以及二叉堆优化(含证明)

    一般最短路径算法习惯性的分为两种:单源最短路径算法和全顶点之间最短路径.前者是计算出从一个点出发,到达所有其余可到达顶点的距离.后者是计算出图中所有点之间的路径距离. 单源最短路径 Dijkstra算 ...

  9. 有向网络(带权的有向图)的最短路径Dijkstra算法

    什么是最短路径? 单源最短路径(所谓单源最短路径就是只指定一个顶点,最短路径是指其他顶点和这个顶点之间的路径的权值的最小值) 什么是最短路径问题? 给定一带权图,图中每条边的权值是非负的,代表着两顶点 ...

随机推荐

  1. JS HTML标签尺寸距离位置定位计算

    四种浏览器对 clientHeight.offsetHeight.scrollHeight.clientWidth.offsetWidth 和 scrollWidth 的解释差异 网页可见区域宽:do ...

  2. NC参照查那个表

    select * from bd_refinfo where name like '%人员工作记录全职树(行政树)%';select * from bd_refinfo where name like ...

  3. 在Activiti官方源码上提交的两个bugfix

    前段时间在Activiti官方源码上提交了两个bugfix,截图为证. 第1个是BPMN model输出的bug:

  4. CSS经典布局-圣杯布局、双飞翼布局

    圣杯布局的来历是2006年发在a list part上的这篇文章:In Search of the Holy Grail · An A List Apart Article圣杯是西方表达“渴求之物&q ...

  5. Js替换地址栏参数

    开了博客竟然有9个月没在来写过了.真是惭愧.今天需要用到一个用js替换地址栏参数的的功能.就自己用JS自己写了一个简单的函数.贴出来仅供大家参考.代码都写了注释.如下: /* js替换URL参数值,无 ...

  6. Apache优化:修改最大并发连接数

    http://www.365mini.com/page/apache-concurrency-configuration.htm Apache是一个跨平台的web服务器,由于其简单高效.稳定安全的特性 ...

  7. 07_XPath_01_入门

    [工程截图] [person.xml] <?xml version="1.0" encoding="UTF-8"?> <students> ...

  8. 392. Is Subsequence

    392. Is Subsequence 水题,先是判断长度,长度t比s小,返回false,然后从左到右扫描t,然后同时扫描s,如果相同,s的index就往后拉一个,如果s的index等于s长度,返回t ...

  9. HIT 1867 经理的烦恼

    题目链接:http://acm.hit.edu.cn/hoj/problem/view?id=1867 每次更新时判断是否素数,如果从非素数变成素数就Update(x, 1),如果从素数变成非素数就U ...

  10. C/C++代码检视要点

    4.1.1       C/C++代码检视要点 代码检视技能属于开发人员的基本功,能够很大程度地反应出开发人员的能力水平,前面4.4.1节已经讲过提高评审检视的方法.下面以实际的C/C++语言方面的代 ...