六度分离(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(迪杰斯特拉)算法是典型的单源最短路径算法,用于计算一个节点到其他所有节点的最短路径.主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止. 问 ...
随机推荐
- 在vue中场景,循环行,点击当前行编辑数据
当前列表 点击编辑,行变为编辑框. <Row style="color:#999;margin-bottom:11px"> <Row style="ma ...
- [转载]C++、C#写的WebService相互调用
[转载]C++.C#写的WebService相互调用 首先感谢永和兄提供C++的WebService服务器端及客户端,并且陪我一起熬夜:然后是火石和我做接口的兄弟,虽然都不知道你叫什么,如果没有你 ...
- ecshop 修改支持php7 方案
修改方法 http://jsb.php-php.com/2016/05/472/ 修改数据库配置 data/config.php
- pycharm中提交Git 忽略部分代码
痛点: 项目中,有些配置项,或者比较隐私的东东,不想上传 解决:在项目根路径下,创建.gitignore 文件 文件中可以写文件名.文件路径等 结果: 提交到git,发现果真没有dbconne ...
- JS 去除字符串空格
$.trim()是jQuery提供的函数,用于去掉字符串首尾的空白字符. "abc 123 def".replace(/\s/g, "") 去除所有的空格
- form 表单onclick事件 禁止表单form提交
最近遇到一次处理form数据的过滤,采用了button的onclick事件来检查,发现return false后表单仍然提交了. 于是仔细研究了下onclick.onsubmit.submit集合函数 ...
- Linux下安装SVN,仓库创建,用户权限管理
Exported from Notepad++ Linux下安装SVN,仓库创建,用户权限管理 1.SVN安装 Ubuntu系统下安装:sudoapt-getinstallsubv ...
- 集训第六周 数学概念与方法 概率 F题
Submit Status Description Sometimes some mathematical results are hard to believe. One of the common ...
- Webdriver元素定位1
元素的定位应该是自动化测试的核心,要想操作一个元素,首先应该识别这个元素. webdriver提供了一系列的元素定位方法,常用的有以下几种: id name class name tag link t ...
- xtu summer individual 6 E - Find Metal Mineral
Find Metal Mineral Time Limit: 1000ms Memory Limit: 65768KB This problem will be judged on HDU. Orig ...