HDOJ--1869--六度分离(用三种算法写的,希望能比較出来他们之间的差别)
六度分离
Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 1791    Accepted Submission(s): 696
Lele对这个理论相当有兴趣,于是,他在HDU里对N个人展开了调查。
他已经得到了他们之间的相识关系,如今就请你帮他验证一下“六度分离”是否成立吧。
对于每组測试。第一行包括两个整数N,M(0<N<100,0<M<200),分别代表HDU里的人数(这些人分别编成0~N-1号),以及他们之间的关系。
接下来有M行。每行两个整数A,B(0<=A,B<N)表示HDU里编号为A和编号B的人互相认识。
除了这M组关系,其它随意两人之间均不相识。
思路:额,把每条边的权值看做1。然后比較随意两个点的距离。看是否存在大于7的。由于是6个朋友,所以应该是7条边以内都能够连接不论什么点。(第一次一遍过一道题,简直开心的不要不要的。)
#include<stdio.h>
#include<string.h>
#define INF 0x3f3f3f3f
int vis[110],map[110][110],dis[110];
int n,m;
void init(){
int i,j;
for(i=0;i<n;i++)
for(j=0;j<n;j++){
if(j==i)
map[i][j]=map[j][i]=0;
else
map[i][j]=map[j][i]=INF;
}
}
void dijkstra(int beg){
int i;
memset(vis,0,sizeof(vis));
for(i=0;i<n;i++)
dis[i]=map[beg][i];
for(i=0;i<n;i++){
int j,k,temp=INF;
for(j=0;j<n;j++)
if(!vis[j]&&temp>dis[j])
temp=dis[k=j];
if(temp==INF)
break;
vis[k]=1;
for(j=0;j<n;j++)
if(!vis[j]&&dis[j]>dis[k]+map[k][j])
dis[j]=dis[k]+map[k][j];
}
}
int main(){
while(scanf("%d%d",&n,&m)!=EOF){
init();
for(int i=0;i<m;i++){
int a,b;
scanf("%d%d",&a,&b);
map[a][b]=map[b][a]=1;
}
int i,j,max=-1;
for(i=0;i<n;i++){
dijkstra(i);
for(j=i;j<n;j++){
if(max<dis[j])
max=dis[j];
}
}
if(max>7)
printf("No\n");
else
printf("Yes\n");
}
return 0;
}
用SPFA做了一次纯粹练一下自己对模板的熟悉度。
#include<stdio.h>
#include<string.h>
#include<queue>
#define N 110
#define M 410
#define INF 0x3f3f3f3f
using namespace std;
int dis[N],vis[N],head[N],n,m,edgenum;
struct node{
int from,to,cost,next;
}edge[M];
void init(){
edgenum=0;
memset(head,-1,sizeof(head));
}
void add(int u,int v){
node E={u,v,1,head[u]};
edge[edgenum]=E;
head[u]=edgenum++;
}
void spfa(int beg){
queue<int>q;
memset(dis,INF,sizeof(dis));
memset(vis,0,sizeof(vis));
dis[beg]=0;
vis[beg]=1;
q.push(beg);
while(!q.empty()){
int i,u=q.front();
q.pop();
vis[u]=0;
for(i=head[u];i!=-1;i=edge[i].next){
int v=edge[i].to;
if(dis[v]>dis[u]+edge[i].cost){
dis[v]=dis[u]+edge[i].cost;
if(!vis[v]){
vis[v]=1;
q.push(v);
}
}
}
}
}
int main(){
while(scanf("%d%d",&n,&m)!=EOF){
init();
while(m--){
int a,b;
scanf("%d%d",&a,&b);
add(a,b);
add(b,a);
}
int i,j,max=-1;
for(i=0;i<n;i++){
spfa(i);
for(j=0;j<n;j++)
if(max<dis[j])
max=dis[j];
}
if(max>7)
printf("No\n");
else
printf("Yes\n");
}
return 0;
}
floyd算法:
#include<stdio.h>
#include<string.h>
#define INF 0x3f3f3f3f
#define N 220
int dis[N][N],n,m;
void init(int num){
memset(dis,INF,sizeof(dis));
for(int i=0;i<num;i++)
for(int j=0;j<num;j++)
if(i==j)
dis[i][j]=0;
}
void floyd(){
for(int k=0;k<n;k++)
for(int i=0;i<n;i++)
for(int j=0;j<n;j++){
if(dis[i][j]>dis[i][k]+dis[k][j])
dis[i][j]=dis[i][k]+dis[k][j];
}
}
int main(){
while(scanf("%d%d",&n,&m)!=EOF){
init(n);
while(m--){
int a,b;
scanf("%d%d",&a,&b);
dis[a][b]=dis[b][a]=1;
}
floyd();
int flag=0;
for(int i=0;i<n;i++)
for(int j=i;j<n;j++)
if(dis[i][j]>7)
flag=1;
if(flag)
printf("No\n");
else
printf("Yes\n");
}
return 0;
}
HDOJ--1869--六度分离(用三种算法写的,希望能比較出来他们之间的差别)的更多相关文章
- jQuery中.bind() .live() .delegate() .on()的区别 和 三种方式写光棒事件 动画
		地狱的镰刀 bind(type,[data],fn) 为每个匹配元素的特定事件绑定事件处理函数. $("a").bind("click",function(){ ... 
- JavaScript--------------------jQuery中.bind() .live() .delegate() .on()的区别 和 三种方式写光棒事件 动画
		bind(type,[data],fn) 为每个匹配元素的特定事件绑定事件处理函数. $("a").bind("click",function(){alert( ... 
- 最短路问题的三种算法&模板
		最短路算法&模板 最短路问题是图论的基础问题.本篇随笔就图论中最短路问题进行剖析,讲解常用的三种最短路算法:Floyd算法.Dijkstra算法及SPFA算法,并给出三种算法的模板.流畅阅读本 ... 
- c语言求回文数的三种算法的描述
		c语言求回文数的三种算法的描述 题目描述 注意:(这些回文数都没有前导0) 1位的回文数有0,1,2,3,4,5,6,7,8,9 共10个: 2位的回文数有11,22,33,44,55,66,77,8 ... 
- Java利用DES/3DES/AES这三种算法分别实现对称加密
		转载地址:http://blog.csdn.net/smartbetter/article/details/54017759 有两句话是这么说的: 1)算法和数据结构就是编程的一个重要部分,你若失掉了 ... 
- 图文实例解析,InnoDB 存储引擎中行锁的三种算法
		前文提到,对于 InnoDB 来说,随时都可以加锁(关于加锁的 SQL 语句这里就不说了,忘记的小伙伴可以翻一下上篇文章),但是并非随时都可以解锁.具体来说,InnoDB 采用的是两阶段锁定协议(tw ... 
- 内存分配---FF、BF、WF三种算法
		动态分区分配是根据进程的实际需要,动态的为之分配内存空间.而在实现可变分区分配时,将涉及到分区分配中 所用的数据结构.分区分配算法和分区的分配与内存回收的过程. 分区分配中的数据结构:(1)描述空闲块 ... 
- Django中三种方式写form表单
		除了在html中自己手写form表单外,django还可以通过 继承django.forms.Form 或django.forms.ModelForm两个类来自动生成form表单,下面依次利用三种方式 ... 
- hdoj 1869 六度分离
		Problem Description 1967年,美国著名的社会学家斯坦利·米尔格兰姆提出了一个名为“小世界现象(small world phenomenon)”的著名假说,大意是说,任何2个素不相 ... 
随机推荐
- Python之FTP传输
			访问FTP,无非两件事情:upload和download,最近在项目中需要从ftp下载大量文件,然后我就试着去实验自己的ftp操作类,如下(PS:此段有问题,别复制使用,可以参考去试验自己的ftp类! ... 
- poj1717 Dominoes (背包)
			A domino is a flat, thumbsized tile, the face of which is divided into two squares, each left blank ... 
- sublime text3安装angularjs插件
			sublime能够支持AngularJS开发那绝对是一件很爽的事情.下面我一步步讲解如何为sublime安装AngularJS插件. 首先提供一个破解版的sublime text 3的下载地址:htt ... 
- 如何禁止虚拟机自动获取DHCP分配的ip地址
			今天在看Hadoop视频学习的时候跟着视频里面修改ip地址,将虚拟机的ip地址修改为192.168.2.3,结果ifconfig显示ip地址为192.168.2.128,用物理主机去ping这两个ip ... 
- android soap webservers 无法执行 报错 ht.call(SOAP_ACTION, envelope);解决方法
			1.可能没有加入网络访问权限,在Manifest里面加入,<uses-permission android:name="android.permission.INTERNET" ... 
- EMD距离
			一.场景介绍 最近在研究一个场景:图片质量评分,给一张图片一个预测的分数. 里面提到了用 EMD(Earth Mover’s Distance)算法来评估两张图片之间的分布距离.下面主要讲解下 ... 
- 转自CSDN,关于状态机
			有限状态机FSM思想广泛应用于硬件控制电路设计,也是软件上常用的一种处理方法(软件上称为FMM--有限消息机).它把 复杂的控制逻辑分解成有限个稳定状态,在每个状态上判断事件,变连续处理为离散数字处理 ... 
- js等待提示通用类
			function WaitingTip (options){ if(!options){ options = { contain ... 
- 快速掌握RabbitMQ(三)——消息确认、持久化、优先级的C#实现
			1 消息确认 在一些场合,如转账.付费时每一条消息都必须保证成功的被处理.AMQP是金融级的消息队列协议,有很高的可靠性,这里介绍在使用RabbitMQ时怎么保证消息被成功处理的.消息确认可以分为两种 ... 
- I.Tower Defense
			给你p个重塔,q个轻塔,把这些塔放在n*m的图中,这些塔会相互攻击同行同列的,轻塔不能受到攻击,重塔能承受一个塔的攻击, 问放的方法数. 先假定n < m. 可以先枚举放轻塔的个数为s,显然,方 ... 
