【UVA1057】Routing

题面

洛谷

题解

有一个比较好想的dp就是\(f_{i,j}\)表示第一个点在\(i\),第二个点在\(j\)的最小点数,但是直接搞不好转移。

考虑建出反图,那么\(j\)表示在反图上的点\(j\)其实是和正图上的是一样的。

这样子的话我们枚举出边转移:

\[f[v][u2]=f[u1][u2]+[u2!=v],((u1,v)\in G)\\
f[u1][v]=f[u1][u2]+[u1!=v],((u2,v)\in G')
\]

然而我们交换两条路径时发现点数会算多,这种情况我们用另一种方式转移:

\[f[u2][u1]=\min(f[u2][u1],f[u1][u2]+dis[u1][u2]-1)
\]

其中\(dis[u1][u2]\)表示\(u1,u2\)间的最短路,可以用\(floyd\)求出。

代码

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <queue>
#include <vector>
using namespace std;
const int INF = 1e9;
const int MAX_N = 105;
int N, M;
int f[MAX_N][MAX_N], dis[MAX_N][MAX_N];
vector<int> G[MAX_N], E[MAX_N];
bool inq[MAX_N][MAX_N];
void spfa() {
queue<pair<int, int> > que;
for (int i = 1; i <= N; i++)
for (int j = 1; j <= N; j++) f[i][j] = INF;
f[1][1] = 1, inq[1][1] = 1, que.push(make_pair(1, 1));
while (!que.empty()) {
pair<int, int> p = que.front(); que.pop();
int x1 = p.first, x2 = p.second;
for (auto v : G[x1])
if (f[v][x2] > f[x1][x2] + (v != x2)) {
f[v][x2] = f[x1][x2] + (v != x2);
if (!inq[v][x2]) inq[v][x2] = 1, que.push(make_pair(v, x2));
}
for (auto v : E[x2])
if (f[x1][v] > f[x1][x2] + (v != x1)) {
f[x1][v] = f[x1][x2] + (v != x1);
if (!inq[x1][v]) inq[x1][v] = 1, que.push(make_pair(x1, v));
}
if (x1 != x2 && f[x2][x1] > f[x1][x2] + dis[x1][x2] - 1) {
f[x2][x1] = f[x1][x2] + dis[x1][x2] - 1;
if (!inq[x2][x1]) inq[x2][x1] = 1, que.push(make_pair(x2, x1));
}
inq[x1][x2] = 0;
}
}
int main () {
int Case = 0;
while (scanf("%d %d", &N, &M) != EOF) {
if (!N && !M) break;
printf("Network %d\n", ++Case);
for (int i = 1; i <= N; i++) G[i].clear(), E[i].clear();
for (int i = 1; i <= N; i++)
for (int j = 1; j <= N; j++) dis[i][j] = INF;
for (int i = 1; i <= N; i++) dis[i][i] = 0;
for (int i = 1; i <= M; i++) {
int u, v; scanf("%d %d", &u, &v);
dis[u][v] = 1, G[u].push_back(v), E[v].push_back(u);
}
for (int k = 1; k <= N; k++)
for (int i = 1; i <= N; i++)
for (int j = 1; j <= N; j++)
dis[i][j] = min(dis[i][j], dis[i][k] + dis[k][j]);
if (dis[1][2] == INF || dis[2][1] == INF) puts("Impossible");
else spfa(), printf("Minimum number of nodes = %d\n", f[2][2]);
putchar('\n');
}
return 0;
}

【UVA1057】Routing的更多相关文章

  1. 【RabbitMQ】 Routing

    Routing 之前的章节里我们构建了一个简单的日志系统.我们可以广播所有的日志消息给所有的接收端. 本节我们将给它添加一个新特性 - 我们将允许只订阅一个消息的子集.例如,我们只将关键的错误消息定位 ...

  2. 【c#】RabbitMQ学习文档(四)Routing(路由)

    (使用Net客户端) 在上一个教程中,我们构建了一个简单的日志系统,我们能够向许多消息接受者广播发送日志消息. 在本教程中,我们将为其添加一项功能 ,这个功能是我们将只订阅消息的一个子集成为可能. 例 ...

  3. 7.ASP.NET MVC 5.0中的Routing【路由】

    大家好,这一篇向大家介绍ASP.NET MVC路由机制.[PS:上一篇-->6. ASP.NET MVC 5.0中的HTML Helpers[HTML帮助类] ] 路由是一个模式匹配系统,它确保 ...

  4. Asp.NET MVC 拍卖网站,拆解【2】 Asp.NET MVC章回,第(1)节

    时间和篇幅所限,MVC不会介绍基本的建站过程,请参照博客园技术专题文章传送门  英语足够好的请直接去微asp.net 官网 传送门(强烈推荐,尤其是想使用最新技术的时候更应该直接去官网),本文主要介绍 ...

  5. Web应用程序系统的多用户权限控制设计及实现-项目架构【3】

    本章主要讲述Web权限管理系统的项目架构,及开发中需要的基本类和相关的CSS,JS文件. 1.1系统结构 本系统搭建开发工具为Visual Studio 2012,采用ASP.NET MVC 4.0技 ...

  6. 【WebApi】————.net WebApi开发(一)

    2013年08月08日 ⁄ 综合 ⁄ 共 554字 ⁄ 字号 小 中 大 ⁄ 评论关闭 [1].部署环境.net4及以上版本. [2].vs2010  开发需单独安装vs2010 sp1和mvc4 m ...

  7. SCI&EI 英文PAPER投稿经验【转】

    英文投稿的一点经验[转载] From: http://chl033.woku.com/article/2893317.html 1. 首先一定要注意杂志的发表范围, 超出范围的千万别投,要不就是浪费时 ...

  8. 【转】ASP.NET MVC教程

    转自:http://www.cnblogs.com/QLeelulu/category/123326.html ASP.NET MVC的最佳实践与性能优化的文章 摘要: 就一些文章链接,就不多废话了. ...

  9. 转:【译】Asp.net MVC 利用自定义RouteHandler来防止图片盗链

    [译]Asp.net MVC 利用自定义RouteHandler来防止图片盗链   你曾经注意过在你服务器请求日志中多了很多对图片资源的请求吗?这可能是有人在他们的网站中盗链了你的图片所致,这会占用你 ...

随机推荐

  1. 二十三、并发编程之深入解析Condition源码

    二十三.并发编程之深入解析Condition源码   一.Condition简介 1.Object的wait和notify/notifyAll方法与Condition区别 任何一个java对象都继承于 ...

  2. VS2019 Nuget找不到包的问题处理

    VS不记得改了什么设置之后,发现找不到EF 解决办法 1.点击右侧的设置按钮 2.弹出窗中左侧树形结构选择“程序包源”,再点击右上方的添加按钮 输入一下信息:https://www.nuget.org ...

  3. 如何在ppt全屏演示时仍然显示任务栏?

    相信做过ppt演讲的人会有这样的体会:有的时候希望全屏ppt时不要直接霸占全部的屏幕,至少希望能够看到任务栏,这样就可以仍然方便切换程序. 如何实现呢? 很简单,看下图吧:) https://www. ...

  4. Python3.x--33个保留字

    查询方法也在下图:

  5. JS调用栈的一些总结

    原文地址 调用栈 调用栈是解释器追踪函数执行流的一种机制.当执行环境中调用了多个函数函数时,通过这种机制,我们能够追踪到哪个函数正在执行,执行的函数体中又调用了哪个函数. 我们知道JavaScript ...

  6. 2.JavaScript中的原型规则以及原型设计模式

    原型规则 原型规则 所有的引用类型(数组.对象.函数),都具有对象特征,即可自由扩展属性: 所有的引用类型,都有一个_proto_ 属性(隐式原型),属性值是一个普通对象: 所有函数,都具有一个pro ...

  7. 安全SECUERITY英文SECUERITY证券

    security Alternative forms secuerity (mostly obsolete) English Alternative forms secuerity Pronuncia ...

  8. Ubuntu下 安卓 adb 命令报:“insufficient permissions for device: user in plugdev group; ”问题的解决办法

    https://blog.csdn.net/freezingxu/article/details/80893025 在接入设备进行联机调试的时候,遇到了这样的问题: insufficient perm ...

  9. 13 ARM指令集与Thumb指令集

    指令格式 ARM基本格式 <opcode>{<cond>}{S}{.W|.N}<Rd>,<Rn>{,<operand2>} opecode: ...

  10. Python 关于列表字典的键值修改

    list (修改列表的索引值) 循环一个列表时,最好不要对原列表有改变大小的操作,这样会影响你的最终结果. #使用负索引进行修改列表 print('First') lis = [11, 22, 33, ...