六度分离

Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)

Total Submission(s): 1791    Accepted Submission(s): 696

Problem Description
1967年。美国著名的社会学家斯坦利·米尔格兰姆提出了一个名为“小世界现象(small world phenomenon)”的著名假说。大意是说。不论什么2个素不相识的人中间最多仅仅隔着6个人,即仅仅用6个人就能够将他们联系在一起。因此他的理论也被称为“六度分离”理论(six degrees of separation)。尽管米尔格兰姆的理论屡屡应验,一直也有非常多社会学家对其兴趣浓厚,可是在30多年的时间里。它从来就没有得到过严谨的证明,仅仅是一种带有传奇色彩的假说而已。 



Lele对这个理论相当有兴趣,于是,他在HDU里对N个人展开了调查。

他已经得到了他们之间的相识关系,如今就请你帮他验证一下“六度分离”是否成立吧。

 
Input
本题目包括多组測试。请处理到文件结束。

对于每组測试。第一行包括两个整数N,M(0<N<100,0<M<200),分别代表HDU里的人数(这些人分别编成0~N-1号),以及他们之间的关系。

接下来有M行。每行两个整数A,B(0<=A,B<N)表示HDU里编号为A和编号B的人互相认识。

除了这M组关系,其它随意两人之间均不相识。

 
Output
对于每组測试,假设数据符合“六度分离”理论就在一行里输出"Yes"。否则输出"No"。
 
Sample Input
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
 
Sample Output
Yes Yes

思路:额,把每条边的权值看做1。然后比較随意两个点的距离。看是否存在大于7的。由于是6个朋友,所以应该是7条边以内都能够连接不论什么点。(第一次一遍过一道题,简直开心的不要不要的。)

ac代码:
  1. #include<stdio.h>
  2. #include<string.h>
  3. #define INF 0x3f3f3f3f
  4. int vis[110],map[110][110],dis[110];
  5. int n,m;
  6. void init(){
  7. int i,j;
  8. for(i=0;i<n;i++)
  9. for(j=0;j<n;j++){
  10. if(j==i)
  11. map[i][j]=map[j][i]=0;
  12. else
  13. map[i][j]=map[j][i]=INF;
  14. }
  15. }
  16. void dijkstra(int beg){
  17. int i;
  18. memset(vis,0,sizeof(vis));
  19. for(i=0;i<n;i++)
  20. dis[i]=map[beg][i];
  21. for(i=0;i<n;i++){
  22. int j,k,temp=INF;
  23. for(j=0;j<n;j++)
  24. if(!vis[j]&&temp>dis[j])
  25. temp=dis[k=j];
  26. if(temp==INF)
  27. break;
  28. vis[k]=1;
  29. for(j=0;j<n;j++)
  30. if(!vis[j]&&dis[j]>dis[k]+map[k][j])
  31. dis[j]=dis[k]+map[k][j];
  32. }
  33. }
  34. int main(){
  35. while(scanf("%d%d",&n,&m)!=EOF){
  36. init();
  37. for(int i=0;i<m;i++){
  38. int a,b;
  39. scanf("%d%d",&a,&b);
  40. map[a][b]=map[b][a]=1;
  41. }
  42. int i,j,max=-1;
  43. for(i=0;i<n;i++){
  44. dijkstra(i);
  45. for(j=i;j<n;j++){
  46. if(max<dis[j])
  47. max=dis[j];
  48. }
  49. }
  50. if(max>7)
  51. printf("No\n");
  52. else
  53. printf("Yes\n");
  54. }
  55. return 0;
  56. }

用SPFA做了一次纯粹练一下自己对模板的熟悉度。

ac代码:
  1. #include<stdio.h>
  2. #include<string.h>
  3. #include<queue>
  4. #define N 110
  5. #define M 410
  6. #define INF 0x3f3f3f3f
  7. using namespace std;
  8. int dis[N],vis[N],head[N],n,m,edgenum;
  9. struct node{
  10. int from,to,cost,next;
  11. }edge[M];
  12. void init(){
  13. edgenum=0;
  14. memset(head,-1,sizeof(head));
  15. }
  16. void add(int u,int v){
  17. node E={u,v,1,head[u]};
  18. edge[edgenum]=E;
  19. head[u]=edgenum++;
  20. }
  21. void spfa(int beg){
  22. queue<int>q;
  23. memset(dis,INF,sizeof(dis));
  24. memset(vis,0,sizeof(vis));
  25. dis[beg]=0;
  26. vis[beg]=1;
  27. q.push(beg);
  28. while(!q.empty()){
  29. int i,u=q.front();
  30. q.pop();
  31. vis[u]=0;
  32. for(i=head[u];i!=-1;i=edge[i].next){
  33. int v=edge[i].to;
  34. if(dis[v]>dis[u]+edge[i].cost){
  35. dis[v]=dis[u]+edge[i].cost;
  36. if(!vis[v]){
  37. vis[v]=1;
  38. q.push(v);
  39. }
  40. }
  41. }
  42. }
  43. }
  44. int main(){
  45. while(scanf("%d%d",&n,&m)!=EOF){
  46. init();
  47. while(m--){
  48. int a,b;
  49. scanf("%d%d",&a,&b);
  50. add(a,b);
  51. add(b,a);
  52. }
  53. int i,j,max=-1;
  54. for(i=0;i<n;i++){
  55. spfa(i);
  56. for(j=0;j<n;j++)
  57. if(max<dis[j])
  58. max=dis[j];
  59. }
  60. if(max>7)
  61. printf("No\n");
  62. else
  63. printf("Yes\n");
  64. }
  65. return 0;
  66. }

floyd算法:

ac代码:
  1. #include<stdio.h>
  2. #include<string.h>
  3. #define INF 0x3f3f3f3f
  4. #define N 220
  5. int dis[N][N],n,m;
  6. void init(int num){
  7. memset(dis,INF,sizeof(dis));
  8. for(int i=0;i<num;i++)
  9. for(int j=0;j<num;j++)
  10. if(i==j)
  11. dis[i][j]=0;
  12. }
  13. void floyd(){
  14. for(int k=0;k<n;k++)
  15. for(int i=0;i<n;i++)
  16. for(int j=0;j<n;j++){
  17. if(dis[i][j]>dis[i][k]+dis[k][j])
  18. dis[i][j]=dis[i][k]+dis[k][j];
  19. }
  20. }
  21. int main(){
  22. while(scanf("%d%d",&n,&m)!=EOF){
  23. init(n);
  24. while(m--){
  25. int a,b;
  26. scanf("%d%d",&a,&b);
  27. dis[a][b]=dis[b][a]=1;
  28. }
  29. floyd();
  30. int flag=0;
  31. for(int i=0;i<n;i++)
  32. for(int j=i;j<n;j++)
  33. if(dis[i][j]>7)
  34. flag=1;
  35. if(flag)
  36. printf("No\n");
  37. else
  38. printf("Yes\n");
  39. }
  40. return 0;
  41. }

HDOJ--1869--六度分离(用三种算法写的,希望能比較出来他们之间的差别)的更多相关文章

  1. jQuery中.bind() .live() .delegate() .on()的区别 和 三种方式写光棒事件 动画

    地狱的镰刀 bind(type,[data],fn) 为每个匹配元素的特定事件绑定事件处理函数. $("a").bind("click",function(){ ...

  2. JavaScript--------------------jQuery中.bind() .live() .delegate() .on()的区别 和 三种方式写光棒事件 动画

    bind(type,[data],fn) 为每个匹配元素的特定事件绑定事件处理函数. $("a").bind("click",function(){alert( ...

  3. 最短路问题的三种算法&模板

    最短路算法&模板 最短路问题是图论的基础问题.本篇随笔就图论中最短路问题进行剖析,讲解常用的三种最短路算法:Floyd算法.Dijkstra算法及SPFA算法,并给出三种算法的模板.流畅阅读本 ...

  4. c语言求回文数的三种算法的描述

    c语言求回文数的三种算法的描述 题目描述 注意:(这些回文数都没有前导0) 1位的回文数有0,1,2,3,4,5,6,7,8,9 共10个: 2位的回文数有11,22,33,44,55,66,77,8 ...

  5. Java利用DES/3DES/AES这三种算法分别实现对称加密

    转载地址:http://blog.csdn.net/smartbetter/article/details/54017759 有两句话是这么说的: 1)算法和数据结构就是编程的一个重要部分,你若失掉了 ...

  6. 图文实例解析,InnoDB 存储引擎中行锁的三种算法

    前文提到,对于 InnoDB 来说,随时都可以加锁(关于加锁的 SQL 语句这里就不说了,忘记的小伙伴可以翻一下上篇文章),但是并非随时都可以解锁.具体来说,InnoDB 采用的是两阶段锁定协议(tw ...

  7. 内存分配---FF、BF、WF三种算法

    动态分区分配是根据进程的实际需要,动态的为之分配内存空间.而在实现可变分区分配时,将涉及到分区分配中 所用的数据结构.分区分配算法和分区的分配与内存回收的过程. 分区分配中的数据结构:(1)描述空闲块 ...

  8. Django中三种方式写form表单

    除了在html中自己手写form表单外,django还可以通过 继承django.forms.Form 或django.forms.ModelForm两个类来自动生成form表单,下面依次利用三种方式 ...

  9. hdoj 1869 六度分离

    Problem Description 1967年,美国著名的社会学家斯坦利·米尔格兰姆提出了一个名为“小世界现象(small world phenomenon)”的著名假说,大意是说,任何2个素不相 ...

随机推荐

  1. NYOJ 747 蚂蚁的难题(三)

    蚂蚁的难题(三) 时间限制:2000 ms  |  内存限制:65535 KB 难度:4   描述 蚂蚁终于把尽可能多的食材都搬回家了,现在开始了大厨计划. 已知一共有 n 件食材,每件食材有一个美味 ...

  2. 九度oj 题目1536:树的最小高度

    题目描述: 给定一棵无向树, 我们选择不同的节点作为根节点时,可以得到不同的高度(即树根节点到叶子节点距离的最大值), 现在求这棵树可能的最低高度. 输入: 输入可能包含多个测试案例. 对于每个测试案 ...

  3. JSPatch安全部署

    前言 这个事JSPatch集成到客户端的第二篇,第一篇链接:http://www.cnblogs.com/hxwj/p/5163158.html 安全部署链接:http://blog.cnbang.n ...

  4. NOJ——1628Alex’s Game(III)(DFS+回溯)

    [1628] Alex’s Game(III) 时间限制: 1000 ms 内存限制: 65535 K 问题描述 Alex likes to play with one and zero as you ...

  5. BZOJ 2820 YY的GCD ——莫比乌斯反演

    我们可以枚举每一个质数,那么答案就是 $\sum_{p}\sum_{d<=n}\mu(d)*\lfloor n / pd \rfloor *\lfloor m / pd \rfloor$ 直接做 ...

  6. [BZOJ3611] [Heoi2014]大工程(DP + 虚树)

    传送门 $dp[i][0]$表示节点i到子树中的所有点的距离之和 $dp[i][1]$表示节点i到子树中最近距离的点的距离 $dp[i][2]$表示节点i到子树中最远距离的点的距离 建好虚树后dp即可 ...

  7. [luoguP2051] [AHOI2009]中国象棋(DP)

    传送门 注释写明了一切 #include <cstdio> #define N 111 #define p 9999973 #define LL long long int n, m; L ...

  8. ASP.NET2.0 ObjectDataSource的使用详解《转》

    原文发布时间为:2008-08-02 -- 来源于本人的百度文章 [由搬家工具导入] ASP.NET2.0 ObjectDataSource的使用详解(2) http://mqingqing123.c ...

  9. BZOJ——1611: [Usaco2008 Feb]Meteor Shower流星雨

    http://www.lydsy.com/JudgeOnline/problem.php?id=1611 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 1 ...

  10. Ajax向前后台传递json和转换

    学生管理系统MVC模式设计心得: jquery .ajax提交data数据格式 jquery 的Ajax方法提交数据,但是是多个参数,具体data的格式如下: data提交的数据类型为:Object  ...