对于一家铁路公司,我们可以首先使用 Floyd 算法求出任

意两点 x, y 间只经过属于该家铁路公司铁路的最短路,那么在新

图中我们在 x, y 间加一条 x 到 y 最短路对应的花费为边权的边。

接下来只要在新图中使用 Floyd 算法求出任意两点间的最

小花费就可以了。

跟昨天写的<跑路>有点像

http://blog.csdn.net/kenxhe/article/details/53072146

总结一下, floyd的优势在于可以求出任意两个点之间的距离, 可利用这种特性来构建新图, 解决问题.

代码不是我的, 将就着看吧

#include<cstdio>
#include<cstring>
#include<algorithm> using namespace std;
const int N=1010;
int p[N],q[N][N],r[N][N],f[N][N][21],ans,cost[20010][21];
int n,m,tot,x,y,z,k,kk,s,t,dis[N][N],c[N][N],fa[N]; int fin(int x)
{
if (fa[x]!=x)
fa[x]=fin(fa[x]);
return fa[x];
} int main()
{
memset(f,0x16,sizeof(f));
scanf("%d%d%d%d%d",&n,&m,&k,&s,&t);
for (int i=1;i<=n;i++) fa[i]=i;
for (int i=1;i<=m;i++)
{
scanf("%d%d%d%d",&x,&y,&z,&kk);
f[x][y][kk]=z;
c[x][y]=kk;
f[y][x][kk]=z;
c[y][x]=kk;
int fx=fin(x),fy=fin(y);
if (fx!=fy)
fa[fx]=fy;
} int fs=fin(s),ft=fin(t);
if (fs!=ft)
{
printf("-1\n");
return 0;
} for (int i=1;i<=k;i++)
scanf("%d",p+i);
for (int i=1;i<=k;i++)
{
for (int j=1;j<p[i];j++)
scanf("%d",&q[i][j]);
for (int j=1;j<=p[i];j++)
scanf("%d",&r[i][j]);
} for (int i=1;i<=k;i++)
for (int j=1;j<=20000;j++)
{
int ii,ans=0;
for (ii=1;ii<p[i];ii++)
{
if (j<q[i][ii]) break;
ans+=(q[i][ii]-q[i][ii-1])*r[i][ii];
}
if (j>q[i][ii-1])
ans+=(j-q[i][ii-1])*r[i][ii];
cost[j][i]=ans;
}
for (int cc=1;cc<=k;++cc)
for (int kk=1;kk<=n;kk++)
for (int i=1;i<=n;i++) if (i!=kk)
for (int j=1;j<=n;j++) if (i!=j)
f[i][j][cc]=min(f[i][j][cc],f[i][kk][cc]+f[kk][j][cc]);
// if (c[i][kk]==c[kk][j])
// f[i][j][c[kk][j]]=min(f[i][j][c[kk][j]],f[i][kk][c[i][kk]]+f[kk][j][c[kk][j]]); for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++) if (i!=j)
for (int col=1;col<=k;col++)
if (f[i][j][col]<20000000)
f[i][j][col]=cost[f[i][j][col]][col]; memset(dis,0x16,sizeof(dis));
for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++) if (i!=j)
for (int col=1;col<=k;col++)
dis[i][j]=min(dis[i][j],f[i][j][col]); for (int kk=1;kk<=n;kk++)
for (int i=1;i<=n;i++) if (i!=kk)
for (int j=1;j<=n;j++) if (i!=j)
dis[i][j]=min(dis[i][j],dis[i][kk]+dis[kk][j]);
printf("%d\n",dis[s][t]);
}

小W旅游railway的更多相关文章

  1. XidianOJ 1076 小W喜欢的数字

    题目描述 大家都知道,小W是一名大帅哥,当然比起Light还是有点儿差距的!帅气的小W认为0-9这些数字,只有1,3,5是完美的. 欲问小W为什么,小W总是说"帅哥,是不需要解释的" ...

  2. 武汉科技大学ACM :1008: 小t和小w

    Problem Description 小t最近学了C语言,他想要在女朋友小w面前展示一下自己的能力,小w喜欢如样例所示的图形, 想让小t写一个程序来输出这样的图形,小t拿到后感觉有点困难,小t不想在 ...

  3. bzoj4665小w的喜糖 dp+容斥

    4665: 小w的喜糖 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 120  Solved: 72[Submit][Status][Discuss] ...

  4. bzoj4665 小w的喜糖(dp+容斥)

    4665: 小w的喜糖 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 222  Solved: 130[Submit][Status][Discuss ...

  5. bzoj2441【中山市选】小W的问题

    题目描述 有一天,小W找了一个笛卡尔坐标系,并在上面选取了N个整点.他发现通过这些整点能够画出很多个“W”出来.具体来说,对于五个不同的点(x1, y1), (x2, y2), (x3, y3), ( ...

  6. 【BZOJ 4665】 4665: 小w的喜糖 (DP+容斥)

    4665: 小w的喜糖 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 94  Solved: 53 Description 废话不多说,反正小w要发喜 ...

  7. 【BZOJ4665】小w的喜糖 容斥+组合数

    [BZOJ4665]小w的喜糖 Description 废话不多说,反正小w要发喜糖啦!! 小w一共买了n块喜糖,发给了n个人,每个喜糖有一个种类.这时,小w突发奇想,如果这n个人相互交换手中的糖,那 ...

  8. bzoj2441 [中山市选2011]小W的问题(debug中)

    2441: [中山市选2011]小W的问题 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 487  Solved: 186[Submit][Statu ...

  9. 小w的喜糖(candy)

    小w的喜糖(candy) 题目描述 废话不多说,反正小w要发喜糖啦!! 小w一共买了n块喜糖,发给了n个人,每个喜糖有一个种类.这时,小w突发奇想,如果这n个人相互交换手中的糖,那会有多少种方案使得每 ...

随机推荐

  1. 【HIHOCODER 1599】逃离迷宫4

    描述 小Hi被坏女巫抓进一座由无限多个格子组成的矩阵迷宫. 小Hi一开始处于迷宫(x, y)的位置,迷宫的出口在(a, b).小Hi发现迷宫被女巫施加了魔法,假设当前他处在(x, y)的位置,那么他只 ...

  2. HTTP认证之基本认证——Basic(一)

    导航 HTTP认证之基本认证--Basic(一) HTTP认证之基本认证--Basic(二) HTTP认证之摘要认证--Digest(一) HTTP认证之摘要认证--Digest(二) 一.概述 Ba ...

  3. Linux学习-YUM 在线升级机制

    这个 yum 是透过分析 RPM 的标头资料后, 根据 各软件的相关性制作出属性相依时的解决方案,然后可以自动处理软件的相依属性问题,以解决软件 安装或移除与升级的问题. 利用 yum 进行查询.安装 ...

  4. 可持久化treap(FHQ treap)

    FHQ treap 的整理 treap = tree + heap,即同时满足二叉搜索树和堆的性质. 为了使树尽可能的保证两边的大小平衡,所以有一个key值,使他满足堆得性质,来维护树的平衡,key值 ...

  5. Django Form two

    Django_Form: 1.class TeacherNewForm(Form): username = fields.CharField( required=True, error_message ...

  6. iOS ifdef ifndef endif

    #ifdef DEBUG //标识符//定义过执行#else//未定义过执行#endif #ifndef DEBUG//标识符//未定义过执行#else//定义过执行#endif #if (5> ...

  7. [POJ 1000] A+B Problem 经典水题 C++解题报告 JAVA解题报告

        A+B Problem Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 311263   Accepted: 1713 ...

  8. Selenium WebDriver-通过键盘事件操作浏览器

    #encoding=utf-8 import unittest import time import chardet from selenium import webdriver class Visi ...

  9. Leetcode23--->Merge K sorted Lists(合并k个排序的单链表)

    题目: 合并k个排序将k个已排序的链表合并为一个排好序的链表,并分析其时间复杂度 . 解题思路: 类似于归并排序的思想,lists中存放的是多个单链表,将lists的头和尾两个链表合并,放在头,头向后 ...

  10. day03_07 变量的重新赋值01

    在cmd中退出python,需要使用quit()命令 name = "Alex Li" name2 = name print(name,name2) name = "Ja ...