题目链接: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. 安装JDK,配置环境变量有感

    前天无事,心血来潮给公司新配的笔记本(win10系统64位)装开发工具,然后不可避免的就装了JDK,顺理成章的需要配置环境变量,结果就出问题了. 配置完成,测试时,在dos命令窗口输入java命令执行 ...

  2. mac os 安装 wget

    1. brew安装: ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/inst ...

  3. [转] .NET领域驱动设计—看DDD是如何运用设计模式颠覆传统架构

    阅读目录: 1.开篇介绍 2.简单了解缘由(本文的前期事宜) 3.DomainModel扩展性(运用设计模式设计模型变化点) 3.1.模型扩展性 3.2.设计模式的使用(苦心专研的设计模式.设计思想可 ...

  4. ecshop的aes加密(封装)

    从一家做shopex,ecstore的公司到一家做b2b的ecshop的公司...来了就要实战,其他的不说了,先来了解什么是php的aes加密吧? aes(高级加密标准),AES的区块长度固定为128 ...

  5. JAVA基础——最简单的多重循环程序

    Java 循环语句之多重循环 循环体中包含循环语句的结构称为多重循环.三种循环语句可以自身嵌套,也可以相互嵌套,最常见的就是二重循环.在二重循环中,外层循环每执行一次,内层循环要执行一圈. 如下所示: ...

  6. IOS 状态栏(UIStatusBar)

    ios上状态栏指的屏幕顶端的20像素高的部分 状态栏分前景和背景两部分 前景部分:就是指的显示电池.时间等部分: 背景部分:就是显示白色或者图片的背景部分: 如下图:前景部分为黑色字体,背景部分为白色 ...

  7. 微信小程序知识总结及案例集锦

    微信小程序知识总结及案例集锦 微信小程序的发展会和微信公众号一样,在某个时间点爆发 学习路径 微信小程序最好的教程肯定是官方的文档啦,点击这里直达 微信官方文档 认真跟着文档看一遍,相信有vue前端经 ...

  8. 2017寒假零基础学习Python系列之 印子

    今日为2017年2月6日,据在慕课网上学习廖雪峰Python教程也快一周左右了,完全是零基础入门Python,大一上学期粗浅的接触学习了C语言,早就听说过Python语言的大名,又想把Python的爬 ...

  9. VB6之阴影图层

    要是能创建半透明的刷子就好了,就不必像这样以图层的方式实现透明阴影效果. 代码: 'code by lichmama@cnblogs.com '绘制阴影图层 Private Declare Funct ...

  10. SQL Server分页查询方法整理

    SQL Server数据库分页查询一直是SQL Server的短板,闲来无事,想出几种方法,假设有表ARTICLE,字段ID.YEAR...(其他省略),数据53210条(客户真实数据,量不大),分页 ...