六度分离(floyd算法,SPFA算法,最短路—Dijkstra算法)
Time Limit : 5000/1000ms (Java/Other) Memory Limit : 32768/32768K (Java/Other)
Total Submission(s) : 36 Accepted Submission(s) : 16
Lele对这个理论相当有兴趣。于是,他在HDU里对N个人展开了调查。
他已经得到了他们之间的相识关系,如今就请你帮他验证一下“六度分离”是否成立吧。
对于每组測试,第一行包括两个整数N,M(0<n<100,0<m<200),分别代表hdu里的人数(这些人分别编成0~n-1号),以及他们之间的关系。 <="" div="" 除了这m组关系。其它随意两人之间均不相识。="" 接下来有m行,每行两个整数a,b(0<="A,B<N)表示HDU里编号为A和编号B的人互相认识。
">
8 7
0 1
1 2
2 3
3 4
4 5
5 6
6 7
8 8
0 1
1 2
2 3
3 4
4 5
5 6
6 7
7 0
Yes
Yes
#include<stdio.h>
#include<string.h>
#define M 10000000
#define min(a,b) (a)>(b)?(b):(a)
int map[202][202];
int vis[202],dist[202];
int n,s,t,flag;
int dijkstra(int s)
{
int min,i,j,k;
memset(vis,0,sizeof(vis));
for(i=0; i<n; i++)
dist[i]=M;
dist[s]=0;
for(i=0; i<n; i++)
{
k=-1;
for(j=0; j<n; j++)
if(!vis[j]&&(k==-1||dist[j]<dist[k]))
k=j;
if(dist[k]>7||k==-1)
{
flag=0;
return 0;
}
vis[k]=1;
for(j=0; j<n; j++)
dist[j]=min(dist[j],dist[k]+map[k][j]);
}
return 1;
} int main()
{
int i,j,x,y,z,m;
while(scanf("%d%d",&n,&m)!=EOF)
{
flag=1;
for(i=0; i<n; i++)
for(j=0; j<n; j++)
map[i][j]=map[j][i]=M;
for(i=0; i<m; i++)
{
scanf("%d%d",&x,&y);
map[y][x]=1;
map[x][y]=1;
}
for(i=0;i<n;i++)
if(!dijkstra(i))//少了一个! break;
if(flag)
printf("Yes\n");
else printf("No\n");
}
return 0;
}
再贴一个spfa算法写的代码。
#include<stdio.h>
#include<queue>
#include<string.h>
#include<algorithm>
using namespace std;
struct stu{
int one,two,val,next;
};
stu edge[30000];
int vid[3000],vist[30000],head[30000],t,N,M,flag;
int spfa(int s)
{
memset(vid,0,sizeof(vid));
memset(vist,0x3f3f3f3f,sizeof(vist));
queue<int> q;
q.push(s);
vid[s]=1;
vist[s]=0;
while(!q.empty())
{
int u=q.front();
q.pop();
vid[u]=0;
for(int i=head[u];i!=-1;i=edge[i].next)
{
int v=edge[i].two;
if(vist[v]>vist[u]+edge[i].val)
{
vist[v]=vist[u]+edge[i].val;
if(!vid[v])
{
q.push(v);
vid[v]=1;
}
}
}
}
for(int i=0;i<N;++i)
if(vist[i]>7)
{
flag=0;
return 0;
}
return 1;
}
void get(int u,int v,int w)
{
stu E={u,v,w,head[u]};
edge[t]=E;
head[u]=t++;
}
int main()
{
while(scanf("%d%d",&N,&M)!=EOF)
{
t=0;
flag=1;
memset(head,-1,sizeof(head));
int i,j,a,b,c;
for(i=0;i<M;i++)
{
scanf("%d%d",&a,&b);
get(a,b,1);
get(b,a,1);
}
for(i=0;i<N;i++)
if(!spfa(i))
break;
if(flag)
printf("Yes\n");
else printf("No\n");
}
return 0;
}
再贴一个floyd()算法写的程序
#include<stdio.h>
#include<string.h>
#define INL 0x3f3f3f3f
#define min(a,b) (a)>(b)?(b):(a)//这个地方弄错了,弄成大于了。把这个改了一下就不超时了
int x[110][110];
int n,m;
void floyd()
{
for(int k=0;k<n;k++)
for(int i=0;i<n;i++)
for(int j=0;j<n;j++)
x[i][j]=min(x[i][j],x[i][k]+x[k][j]);
}
int main()
{
int i,j,k,flag,a,b;
while(scanf("%d%d",&n,&m)!=EOF)
{
for(i=0;i<n;i++)//这个地方应该写成n,错写成m了<img alt="哭" src="http://static.blog.csdn.net/xheditor/xheditor_emot/default/cry.gif" />
for(j=0;j<m;j++)
x[i][j]=INL;
for(i=0;i<m;i++)
{
scanf("%d%d",&a,&b);
x[a][b]=x[b][a]=1;
}
floyd();
flag=0;
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
if(x[i][j]>7||x[i][j]==INL)
{
flag=1;
break;
}
if(flag)
break;
}
if(flag)
printf("No\n");
else printf("Yes\n");
}
return 0;
}
六度分离(floyd算法,SPFA算法,最短路—Dijkstra算法)的更多相关文章
- 单源最短路dijkstra算法&&优化史
一下午都在学最短路dijkstra算法,总算是优化到了我能达到的水平的最快水准,然后列举一下我的优化历史,顺便总结总结 最朴素算法: 邻接矩阵存边+贪心||dp思想,几乎纯暴力,luoguTLE+ML ...
- 最短路Dijkstra算法的一些扩展问题
最短路Dijkstra算法的一些扩展问题 很早以前写过关于A*求k短路的文章,那时候还不明白为什么还可以把所有点重复的放入堆中,只知道那样求出来的就是对的.知其然不知其所以然是件容易引发伤痛的 ...
- 【POJ - 3268 】Silver Cow Party (最短路 Dijkstra算法)
Silver Cow Party Descriptions 给出n个点和m条边,接着是m条边,代表从牛a到牛b需要花费c时间,现在所有牛要到牛x那里去参加聚会,并且所有牛参加聚会后还要回来,给你牛x, ...
- Python数据结构与算法之图的最短路径(Dijkstra算法)完整实例
本文实例讲述了Python数据结构与算法之图的最短路径(Dijkstra算法).分享给大家供大家参考,具体如下: # coding:utf-8 # Dijkstra算法--通过边实现松弛 # 指定一个 ...
- luogu P3371 & P4779 单源最短路径spfa & 最大堆优化Dijkstra算法
P3371 [模板]单源最短路径(弱化版) 题目背景 本题测试数据为随机数据,在考试中可能会出现构造数据让SPFA不通过,如有需要请移步 P4779. 题目描述 如题,给出一个有向图,请输出从某一点出 ...
- ACM: HDU 2544 最短路-Dijkstra算法
HDU 2544最短路 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Descrip ...
- 单源最短路Dijkstra算法——matlab实现
迪杰斯特拉(Dijkstra)算法是典型最短路径算法,用于计算一个节点到其他节点的最短路径. 它的主要特点是以起始点为中心向外层层扩展(广度优先搜索思想),直到扩展到终点为止. 基本思想 通过Dijk ...
- hdu2544 最短路 Dijkstra算法
最短路(Dijkstra算法模板题) Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Other ...
- 单源最短路(Dijkstra算法)
#返回上一级 @Author: 张海拔 @Update: 2015-03-11 @Link: http://www.cnblogs.com/zhanghaiba/p/3514570.html Dijk ...
- 单源最短路——dijkstra算法
Dijkstra算法 1.定义概览 Dijkstra(迪杰斯特拉)算法是典型的单源最短路径算法,用于计算一个节点到其他所有节点的最短路径.主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止. 问 ...
随机推荐
- java组件不存在解决方案:右侧Maven Projects展开后左上角第一个刷新按钮 刷新后就会从新加载所有java的依赖项了
java组件不存在解决方案:右侧Maven Projects展开后左上角第一个刷新按钮 刷新后就会从新加载所有java的依赖项了 软件:idea 问题产生:其他同事进行开发,引入新java组件后提交 ...
- bat2exe 就是这么简单 白研究半天VC++了
bat2exe 就是这么简单 白研究半天VC++了 结果:bat2exe编译的执行文件会被杀毒软件查杀.
- springboot实现web应用过程中的摸爬打滚(持续更新ing)
最近在做公司的网站项目,后端用到springboot.怎么说呢,记录总结一下自己开发过程中遇到的坑和一些心得体会,以及一些技巧.方便以后回顾复习,也供同行们参考. 开发环境:eclipse2018-1 ...
- java实现zip,gzip,7z,zlib格式的压缩打包
本文主要介绍的是通过使用java的相关类可以实现对文件或文件夹的压缩. zlib是一种数据压缩程序库,它的设计目标是处理单纯的数据(而不管数据的来源是什么). 7z 是一种新的压缩格式,它拥有目前最高 ...
- 通俗易懂的Redux了解下
Redux真的让我脑仁疼,感觉有点搞不定他,因为对我而言太抽象了.所以我用通俗易懂地方法去思考Redux,感觉能够理解了. 本文要点: action 配置行为 store.dispatch(actio ...
- BZOJ1001 狼抓兔子 平面图转对偶图 最小割
现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的,而且现在的兔子还比较笨,它们只有两个窝,现在你做为狼王,面对下面这样一个网格的地形: 左上角点为 ...
- HYSBZ - 3750 Pieczęć(模拟)
题目: 一张n*m的方格纸,有些格子需要印成黑色,剩下的格子需要保留白色. 你有一个a*b的印章,有些格子是凸起(会沾上墨水)的.你需要判断能否用这个印章印出纸上的图案.印的过程中需要满足以下要求: ...
- mybatis传多个参数(不使用@param注解情况下),3.4.2版本之后出现#{0}-#{n}参数绑定异常
解决方案: 在mybatis配置文件中声明setting属性的useActualParamName 参数值为false ** 这种方法解决mybatis3.4.2之后的版本产生该问题的解决方法**
- <Redis> 入门五 持久化RBD/AOF
RDB RDB持久化是指在指定的时间间隔内将内存中的数据集快照写入磁盘(默认是 dump.rdb). 默认持久化机制,就是将内存中的数据以快照的方式写入二进制文件dump.rbd中. 触发快照的条件 ...
- python3.x Day5 异常处理
异常处理: 预计可能会发生的异常,明确如果发生,如何处理,不过一般不参与业务逻辑,也不要一次性捕捉全部异常,不然可能程序就不可控了. data={} mmm=[] try: #捕获异常, data[& ...