点我看题目

题意 :中文不详述。

思路 :因为这个题加了一个要求就是路径数目得是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. MySQL索引详解

    导读:大家都知道,一个MySQL数据库能够储存大量的数据,如果要查找那一个数据,就得费好大劲从一大堆的数据中找到,即费时间又费力气,这时,索引的出现就大大减轻了数据库管理员的工作.本文介绍了数据库索引 ...

  2. Singleton(单例模式)

    类的实例化次数只能一次. 例如:小王和小李通过门铃进行沟通,首先判断小王家是否有门,若没有建立门,若有门直接返回门. var xiaowang = (function(argument){ var m ...

  3. 2015年校园招聘12家IT公司面试体验

    背景 2015年注定是一个不平凡的年头,作为一个应届毕业生,我也算是经历了工作上的大起大落.下面我先简单讲述一下自己的遭遇,然后根据自己亲身的面试经历,从一个学生的角度去谈谈自己对面试过的公司的一些看 ...

  4. ASP实现随机提取数据库记录例

    <% "一个从数据库中随机读取纪录的例子 Set Rs1=server.CreateObject ("adodb.recordset") Set Rs=server ...

  5. ACM——快速排序法

    快速排序 时间限制(普通/Java):1000MS/3000MS          运行内存限制:65536KByte总提交:653            测试通过:297 描述 给定输入排序元素数目 ...

  6. Cordova+angularjs+ionic+vs2015开发(五)

    欢迎加群学习:457351423 这里有4000多部学习视频,涵盖各种技术,有需要的欢迎进群学习! 一.创建侧边菜单和导航项目 1.使用VS创建一个Ionic空项目,同时创建一个Ionic SideM ...

  7. SVG实现描边动画

    说起SVG,我是恨它又爱它,恨它是因为刚开始接触的时候自己傻B地想用代码去写它,其实在web上我们用它做交互也只是用了几个常用的特性而已,其他的标签知道这么一回事就成了,其实说白了它就是一种图片格式, ...

  8. fgetc, getchar(), fscanf的问题

    1.漫谈:为什么 函数fscanf(FILE stream, const char format, ...)的 第3个参数中 总是用变量的地址 或者是用指针. 这个问题涉及到 传值 和 传指针.一般情 ...

  9. 第33条:用EnumMap代替序数索引

    有时候,会见到利用ordinal方法来索引数组的代码.例如下面这个简化的类,表示一种烹饪用的香草: public class Herb { public enum Type { ANNUAL, PER ...

  10. treeview OnSelectedNodeChanged js的方法

    可以在OnSelectedNodeChanged的cs中,对node赋值如此: nod.Text = "<span onclick=''>" + node名称 + &q ...