Floyd大家可能第一时间想到的是他求多源最短路的n³算法。其实它还有另外两种算法的嘛qwq。写一发总结好了qwq。

一、多源最短路

放段代码跑,注意枚举顺序,用邻接矩阵存图。本质是一种动规。

复杂度O(n³)。

 for(int k=;k<=n;k++)
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
f[i][j]=min(f[i][j],f[i][k]+f[k][j]);

放个例题跑。

灾后重建

二、传递闭包

在交际网络中,给定若干个元素,若干个二元关系,关系有传递性。传递闭包就是一种“通过传递性推导出尽量多的元素之间关系的问题”,求出可确定排名的元素个数。

实现用一个布尔型的邻接矩阵,f[i][j]=1表示i与j有关系,否则则没有关系。

我们每次可以枚举k点,来解决那些间接相关的关系处理。

 for(int k=;k<=n;k++)
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
f[i][j]|=f[i][k]&f[k][j];

例题 [USACO08JAN]牛大赛Cow Contest

对于奶牛的编程能力,用f[i][j]=1表示i比j强,之后就是一个裸的传递闭包。跑一遍后n²统计每只牛它与其他牛的关系是否已经确定,意思就是说只要有f[i]j]=1或f[j][i]=1其中一个就行,来统计答案。

Code

 #include<cstdio>
#include<algorithm> using namespace std; int n,m,ans;
int f[][]; int main()
{
scanf("%d%d",&n,&m);
for(int i=;i<=m;i++)
{
int x=,y=;
scanf("%d%d",&x,&y);
f[x][y]=;
}
for(int k=;k<=n;k++)
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
f[i][j]|=f[i][k]&f[k][j];
for(int i=;i<=n;i++)
{
int j;
for(j=;j<=n;j++)
{
if(i==j) continue;
if(f[i][j]==&&f[j][i]==) break;
}
if(j>n) ans++;
}
printf("%d",ans);
return ;
}

三、求无向图最小环

例题1 USACO4.1篱笆回路

这道题难在建图,图建好以后就是裸的跑floyd找最小环了。

(瞎说一句,这题竟然有个数组开了1000的空间,但是越界了呀qwq)

Code

 /*
ID:cellur_2
TASK:fence6
LANG:C++
*/
#include<cstdio>
#include<algorithm>
#include<cstring> using namespace std;
const int inf=0x3f3f3f3f; int n,num,ans=inf;
int dis[][],mapp[][];
struct node{
int len;
int lcnt,rcnt,lid,rid,id;
int l[],r[];
}edge[]; int main()
{
scanf("%d",&n);
for(int i=;i<=n;i++)
{
scanf("%d",&edge[i].id);
int x=edge[i].id;
scanf("%d",&edge[x].len);
scanf("%d%d",&edge[x].lcnt,&edge[x].rcnt);
for(int j=;j<=edge[x].lcnt;j++)
scanf("%d",&edge[x].l[j]);
for(int j=;j<=edge[x].rcnt;j++)
scanf("%d",&edge[x].r[j]);
}
for(int i=;i<=n;i++)
{// lid 这条边左端点的点编号
// rid 这条边右端点的点编号
if(!edge[i].lid) edge[i].lid=++num;
for(int j=;j<=edge[i].lcnt;j++)
{
int x=edge[i].l[j];
bool flag=;
for(int k=;k<=edge[x].lcnt;k++)
if(edge[x].l[k]==i)
{
flag=;
break;
}
if(flag) edge[x].lid=edge[i].lid;
else edge[x].rid=edge[i].lid;
}
if(!edge[i].rid) edge[i].rid=++num;
for(int j=;j<=edge[i].rcnt;j++)
{
int x=edge[i].r[j];
bool flag=;
for(int k=;k<=edge[x].lcnt;k++)
if(edge[x].l[k]==i)
{
flag=;
break;
}
if(flag) edge[x].lid=edge[i].rid;
else edge[x].rid=edge[i].rid;
}
}
memset(mapp,0x3f,sizeof(mapp));
memset(dis,0x3f,sizeof(dis));
ans=dis[][];
for(int i=;i<=n;i++) mapp[i][i]=,dis[i][i]=;
for(int i=;i<=n;i++)
{
int lid=edge[i].lid;
int rid=edge[i].rid;
int len=edge[i].len;
mapp[rid][lid]=mapp[lid][rid]=len;
dis[rid][lid]=dis[lid][rid]=len;
}
//floyd找最小环
for(int k=;k<=num;k++)
{
for(int i=;i<k;i++)
for(int j=i+;j<k;j++)
ans=min(ans,dis[i][j]+mapp[i][k]+mapp[k][j]);
for(int i=;i<=num;i++)
for(int j=;j<=num;j++)
dis[i][j]=min(dis[i][j],dis[i][k]+dis[k][j]);
}
printf("%d\n",ans);
return ;
}

例题2 POJ 1734 Sightseeing Trip

其实是floyd找最小环的板子题,但是由于题目要求输出一种合法的方案,所以我们只要再开一个vector就行了。

Code

 #include<cstdio>
#include<algorithm>
#include<vector>
#include<cstring> using namespace std;
typedef long long ll; int n,m;
int ans=0x3f3f3f3f;
int dis[][],mapp[][],pos[][];
vector<int>path; void get_path(int x,int y)
{
if(pos[x][y]==) return ;
get_path(x,pos[x][y]);
path.push_back(pos[x][y]);
get_path(pos[x][y],y);
} int main()
{
scanf("%d%d",&n,&m);
memset(dis,0x3f,sizeof(dis));
for(int i=;i<=n;i++) dis[i][i]=;
for(int i=;i<=m;i++)
{
int x=,y=,z=;
scanf("%d%d%d",&x,&y,&z);
dis[x][y]=dis[y][x]=min(dis[x][y],z);
}
memcpy(mapp,dis,sizeof(dis));
for(int k=;k<=n;k++)
{
for(int i=;i<k;i++)
for(int j=i+;j<k;j++)
if((ll)mapp[i][j]+dis[j][k]+dis[i][k]<ans)
{
ans=mapp[i][j]+dis[i][k]+dis[k][j];
path.clear();
path.push_back(i);
get_path(i,j);
path.push_back(j);
path.push_back(k);
}
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
if(mapp[i][j]>mapp[i][k]+mapp[k][j])
{
mapp[i][j]=mapp[i][k]+mapp[k][j];
pos[i][j]=k;
}
}
if(ans==0x3f3f3f3f)
{
printf("No solution.");
return ;
}
for(int i=;i<path.size();i++)
printf("%d ",path[i]);
return ;
}

浅谈Floyd的三种用法 By cellur925的更多相关文章

  1. iOS——浅谈iOS中三种生成随机数方法

    ios 有如下三种随机数方法:

  2. 浅谈js函数三种定义方式 & 四种调用方式 & 调用顺序

    在Javascript定义一个函数一般有如下三种方式: 函数关键字(function)语句: function fnMethodName(x){alert(x);} 函数字面量(Function Li ...

  3. 浅谈WCF的三种通信模式:请求响应模式、数据报模式和双工通讯模式

    一: WCF的服务端与客户端在通信时有三种模式:请求响应模式.数据报模式和双工通讯模式. 说一下基本知识,  1.如果想要将当前接口作为wcf服务器,则一定要加上[ServiceContract] 契 ...

  4. 浅谈c#的三个高级参数ref out 和Params C#中is与as的区别分析 “登陆”与“登录”有何区别 经典SQL语句大全(绝对的经典)

    浅谈c#的三个高级参数ref out 和Params   c#的三个高级参数ref out 和Params 前言:在我们学习c#基础的时候,我们会学习到c#的三个高级的参数,分别是out .ref 和 ...

  5. 【转】浅谈常用的几种web攻击方式

    浅谈常用的几种web攻击方式 一.Dos攻击(Denial of Service attack) 是一种针对服务器的能够让服务器呈现静止状态的攻击方式.有时候也加服务停止攻击或拒绝服务攻击.其原理就是 ...

  6. 浅谈Spring的两种配置容器

    浅谈Spring的两种配置容器 原文:https://www.jb51.net/article/126295.htm 更新时间:2017年10月20日 08:44:41   作者:黄小鱼ZZZ     ...

  7. using 的三种用法

    using 有哪三种用法? 1)引入命名空间. 2)给命名空间或者类型起别名. 3)划定作用域.自动释放资源,使用该方法的类型必须实现了 System.IDisposable接口,当对象脱离作用域之后 ...

  8. Js闭包常见三种用法

        Js闭包特性源于内部函数可以将外部函数的活动对象保存在自己的作用域链上,所以使内部函数的可以将外部函数的活动对象占为己有,可以在外部函数销毁时依然存有外部函数内的活动对象内容,这样做的好处是可 ...

  9. .NET(c#)new关键字的三种用法

    前几天去家公司面试,有一道这样的题:写出c#中new关键字的三种用法,思前想后挖空心思也只想出了两种用法,回来查了下msdn,还真是有第三种用法:用于在泛型声明中约束可能用作类型参数的参数的类型,这是 ...

随机推荐

  1. 这样看ACM是不是更好?

    如果搞ACM只是为了拿奖,为了保研,这样太功利,整个过程都会变得没意思.我说过我同时看中过程和结果. 其实ACM解题也不是那么没意思,每次AC都有一种非常棒的成就感,每个题目就像是一个解谜游戏,完成了 ...

  2. JavaScript 模拟键盘事件

    JavaScript 模拟键盘事件和鼠标事件(比如模拟按下回车等) 2016年09月08日 15:23:25 神秘_博士 阅读数:41158 标签: javascript鼠标键盘事件模拟更多 个人分类 ...

  3. [游戏]L4D求生之路官方比赛地图修补完好说明

    游戏模式:L4D求生之路4356(1.0.2.1)药抗比赛模式 更新日期:2015.06.04 -----毫不留情01----- 1.开局补给手枪 -----毫不留情02----- 1.开局补给手枪 ...

  4. 【前端JS】radio 可单选可点击取消选中

    普通情况下 radio 单选框仅仅能实现多选一的效果,可是一旦选择当中一个后,这个单选框就不可点击取消其选中状态了.这样的功能在某些业务环境下并不适用.有时我们既须要单选框的多选一效果.也须要复选框的 ...

  5. GDI泄露+改EXE名

    CDC 应该是成对使用 GetDC and ReleaseDC(不用new and delete) 泄露 1.改变生产exe名称:工程->设置->连接->输出文件名:Release/ ...

  6. 在C++中使用Libmd5计算字符串或文件的MD5值

    CppMD5Demo.cpp #include <iostream> #include <fstream> #include <chrono> #include & ...

  7. UDP 端到端

    创建发送端 1.建立DatagramSocket对象,该端点建立,系统会随机分配一个端口,如果不想随机分配,可手动指定. 2.将数据进行packet封装,必须指定目的地址和端口. 3.通过socket ...

  8. 百度自然语言处理api用法

    def words url = "https://aip.baidubce.com/rpc/2.0/nlp/v1/lexer?access_token=1111111" param ...

  9. SVN回滚机制

    引子 工作中遇到一个新同事提交代码时不知怎么的出现了大面积的代码覆盖,由于对SVN也不是特别了解,就看着别人处理问题,自己也验证性的实践了一下,总结一下. 总结 svn每一次提交成功,都会有一个`编号 ...

  10. GPS常见故障

    当出现故障时,依据可能原因进行排查. 下表列举典型故障及调试方法 现象 root cause 检查 实验   GPS无法开启/无法搜星 软件配置错误 SW 相关配置(如GPIO等) 录制mobile ...