题目链接:https://vjudge.net/problem/HYSBZ-1491

题目大意:中文题目,题意见题目

题目分析:由于数据量很小,可以考虑进行Floyd算法。

第一次进行Floyd算法,算出两点之间的最短路径,另外记录下这两点之间有多长条最短路走法。

第二场进行类似Floyd算法的方法,计算经过k点,是否可以走出最短路,如果可以的话,进行计算。

注意在两次统计计算的过程中,要用组合的方法,即num[i][j]=num[i][k]*num[k][j];

给出代码:

 #include <iostream>
 #include <cstdio>
 #include <queue>
 #include <cstring>
 #include <string>
 using namespace std;

 int n,m;
 +][+];
 +][+];
 int inf=0x3f3f3f;
 ];
 int main()
 {
     cin>>n>>m;
     memset(node,inf,sizeof(node));
     //memset(node1,0,sizeof(node1));
     // memset(mark,0,sizeof(mark));
     ; i<m; i++)
     {
         int a,b,c;
         scanf("%d%d%d",&a,&b,&c);
         node[a][b]=c;
         node[b][a]=c;
         node1[a][b]=;
         node1[b][a]=;
     }
     // for(int i=1; i<=n; i++)
     //      node[i][i]=0;
   /*  for(int i=1; i<=n; i++)
     {
         for(int j=1; j<=n; j++)
         {
             cout<<node[i][j]<<" ";
         }
         cout<<endl;
     }
     cout<<endl;*/
     ; k<=n; k++)
     {
         ; i<=n; i++)
         {
             ; j<=n; j++)
             {
                 if(k!=i&&k!=j&&i!=j)
                 {
                     if(node[i][j]==node[i][k]+node[k][j])
                         node1[i][j]=node1[i][j]+(node1[i][k]*node1[k][j]);
                     else if(node[i][j]>node[i][k]+node[k][j])
                     {
                         node1[i][j]=node1[i][k]*node1[k][j];
                         node[i][j]=node[i][k]+node[k][j];
                     }
                 }
                // node[i][j]=
             }
         }
     }
    /* for(int i=1; i<=n; i++)
     {
         for(int j=1; j<=n; j++)
         {
             cout<<node[i][j]<<" ";
         }
         cout<<endl;
     }*/
     ; k<=n; k++)
     {
         ; i<=n; i++)
         {
             ; j<=n; j++)
             {

                 )
                 {
                     mark[k]+=((node1[i][k]*node1[k][j])/node1[i][j]);
                     // cout<<mark[k]<<" "<<k<<" "<<i<<" "<<j<<endl;
                  //   cout<<node1[i][k]<<" "<<node1[k][j]<<endl;
                 }
             }
         }
     }
     ; i<=n; i++)
         printf("%.3f\n",mark[i]);
     ;
 }

BZOJ-1491-社交网络的更多相关文章

  1. BZOJ 1491 社交网络 Floyd 最短路的数目

    题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=1491 题目大意: 见链接 思路: 直接用floyd算法求最短路,同时更新最短路的数目即 ...

  2. BZOJ 1491 社交网络(最短路)

    对于这道题,如果我们能求出s到t的最短路径数目和s由v到t的最短路径数目,剩下的很好求了. 令dis[i][j]表示i到j的最短路径,dp[i][j]表示i到j的最短路径条数,如果dis[s][v]+ ...

  3. BZOJ 1491 [NOI2007]社交网络

    1491: [NOI2007]社交网络 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 1159  Solved: 660[Submit][Status] ...

  4. BZOJ 1491: [NOI2007]社交网络( floyd )

    floyd...求最短路时顺便求出路径数. 时间复杂度O(N^3) ------------------------------------------------------------------ ...

  5. 【BZOJ 1491】 [NOI2007]社交网络

    Description Input Output 输出文件包括n 行,每行一个实数,精确到小数点后3 位.第i 行的实数表 示结点i 在社交网络中的重要程度. Sample Input 4 4 1 2 ...

  6. BZOJ 1491: [NOI2007]社交网络(Floyd+暴力乱搞)

    题面: https://www.lydsy.com/JudgeOnline/problem.php?id=1491 题解: 先看数据范围,n<=100..欸可以乱搞了 首先因为小学学过的乘法原理 ...

  7. bzoj 1491 floyd

    我们用w[i][j]表示i到j的最短路的数量,dis[i][j]表示i到j的最短路,那么我们在floyd的时候,如果dis[i][k]+dis[k][j]==dis[i][j],根据乘法原理我们就w[ ...

  8. bzoj 1491

    思路:先求出每两点之间的最短路,建出n个最短路径图,然后枚举起点终点和中间点,计算条数用到拓扑图dp... 看别人的方法很巧妙地用floyd在计算最短路的时候就可以直接计算条数啦... #includ ...

  9. BZOJ1491: [NOI2007]社交网络

    传送门 最短路计数问题.因为数据量非常小($N \leq 100$),所以Floyd随便搞搞就行了. $f[i][j]$表示路径长度,$g[i][j]$表示最短路方案数. 先跑一遍裸的Floyd,然后 ...

  10. 【BZOJ】1491: [NOI2007]社交网络(floyd)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1491 囧囧囧...................... 囧1:虽然自己想到做法了,但是操作的时候, ...

随机推荐

  1. iOS enum C方法 DEBUG, RELEASE的隐藏的一个坑

    开发了一个app, 在debug模式下没有任何问题,在release模式下就直接崩溃. 经过一段时间的定位终于定位到如下的这一段代码: E_BZ_TestType type = [dic[@" ...

  2. DllImport 自动选择x64或x86 dll

    前言 标题不知道怎么确切地命名,在.net的托管世界里,有时不得不使用c的某个动态库,比如ocr.opencv等,如果幸运,有前人已经包装出.net版本,但有些不非常流行的库,只能自己使用pinvok ...

  3. vue-router如何根据不同的用户给不同的权限

    闲聊: 小颖去年在上家公司用的vue1.0之前在做路由这块用的router.map,但是现在vue2.0里已经不能用了,所以之前解决权限问题的例子,小颖也参考不了呜呜 之前看一个美女写的:elemem ...

  4. Deep Q-Network 学习笔记(二)—— Q-Learning与神经网络结合使用(有代码实现)

    参考资料: https://morvanzhou.github.io/ 非常感谢莫烦老师的教程 http://mnemstudio.org/path-finding-q-learning-tutori ...

  5. thinkphp 单字母函数

    在ThinkPHP中有许多使用简便的单字母函数(即快捷方法),可以很方便开发者快速的调用,但是字母函数却不方便记忆,本文将所有的字母函数总结一下,以方便以后查找. 1.U() URL组装 支持不同UR ...

  6. java 二叉树实现

    //二叉树,有左子数,右子树,小的值放到左边,大的值放到右边,左边有树的话继续这个过程,(以下为代部分,赋值的时候采用了递归的方式) package liaobiao;class BiTree{ pr ...

  7. 用window的onload事件,窗体加载完毕的时候

    <script type="text/javascript"> //用window的onload事件,窗体加载完毕的时候 window.onload=function( ...

  8. accp8.0转换教材第4章MySQL高级查询(二)理解与练习

    知识点:EXISTS子查询.NOT EXISTS子查询.分页查询.UNION联合查询 一.单词部分 ①exist存在②temp临时的③district区域 ④content内容⑤temporary暂时 ...

  9. dynamic-load-apk 插件与宿主方法互调

    新建项目 DlPluginHost,下载dynamic-load-apk源码 1.将dynamic-load-apk 文件夹中的lib做为module导入到DlPlginHost 2.导入到Plugi ...

  10. opencv如何实现【不用全局变量进行滚动条控制】

    opencv中自带滚动条,其中一个问题是该回调函数(on_trackbar)大多使用的是全局变量,大型项目调试时弊端众多,比如下图: 为此,留意了void on_Trackbar(int par1, ...