博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【BZOJ5297】【CQOI2018】社交网络(矩阵树定理)
阅读量:4315 次
发布时间:2019-06-06

本文共 1718 字,大约阅读时间需要 5 分钟。

【BZOJ5297】【CQOI2018】社交网络(矩阵树定理)

题面

Description

当今社会,在社交网络上看朋友的消息已经成为许多人生活的一部分。通常,一个用户在社交网络上发布一条消息

(例如微博、状态、Tweet等)后,他的好友们也可以看见这条消息,并可能转发。转发的消息还可以继续被人转

发,进而扩散到整个社交网络中。在一个实验性的小规模社交网络中我们发现,有时一条热门消息最终会被所有人

转发。为了研究这一现象发生的过程,我们希望计算一条消息所有可能的转发途径有多少种。为了编程方便,我们

将初始消息发送者编号为1,其他用户编号依次递增。该社交网络上的所有好友关系是已知的,也就是说对于A、B

两个用户,我们知道A用户可以看到B用户发送的消息。注意可能存在单向的好友关系,即A能看到B的消息,但B不

能看到A的消息。

还有一个假设是,如果某用户看到他的多个好友转发了同一条消息,他只会选择从其中一个转发,最多转发一次消

息。从不同好友的转发,被视为不同的情况。

如果用箭头表示好友关系,下图展示了某个社交网络中消息转发的所有可能情况。

img

初始消息是用户1发送的,加粗箭头表示一次消息转发

Input

输入文件第一行,为一个正整数n,表示社交网络中的用户数:

第二行为一个正整数m.表示社交网络中的好友关系数目。

接下来m行,每行为两个空格分隔的整数ai和bi,表示一组好友关系,即用户ai可以看到用户bi发送的消息。

1≤n≤250,1≤ai,bi≤n,1≤m≤n(n-1)

Output

输出文件共一行,为一条消息所有可能的转发途径的数量,除以1 0007所得的余数。

Sample Input

4

7
2 1
3 1
1 3
2 3
3 2
4 3
4 2

Sample Output

6

题解

所以,\(CQOI2018\)是模板题大赛吗???

这就是一个有向图的矩阵树定理的模板题啊。。

#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
using namespace std;#define ll long long#define RG register#define MAX 255#define MOD 10007inline int read(){ RG int x=0,t=1;RG char ch=getchar(); while((ch<'0'||ch>'9')&&ch!='-')ch=getchar(); if(ch=='-')t=-1,ch=getchar(); while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar(); return x*t;}int a[MAX][MAX],n,m;int main(){ n=read();m=read(); for(int i=1;i<=m;++i) { int u=read(),v=read(); a[v][u]--;a[u][u]++; } int ans=1; for(int i=2;i<=n;++i) for(int j=i+1;j<=n;++j) while(a[j][i]) { int t=a[i][i]/a[j][i]; for(int k=i;k<=n;++k)a[i][k]=(a[i][k]+MOD-a[j][k]*t%MOD)%MOD,swap(a[i][k],a[j][k]); ans*=-1; } for(int i=2;i<=n;++i)ans=ans*a[i][i]%MOD; printf("%d\n",(ans+MOD)%MOD);}

转载于:https://www.cnblogs.com/cjyyb/p/8898620.html

你可能感兴趣的文章
简单字符串处理应避免使用正则表达式
查看>>
了解正则表达式操作符的优先级
查看>>
Spring框架集成FreeMarker
查看>>
用 async/await 来处理异步
查看>>
app开发-1
查看>>
在JavaScript中调用ASP.NET WebService的简单方法
查看>>
jQuery基础知识,很赞的!!!
查看>>
[SDOI 2012]Longge的问题
查看>>
简单BBS项目开始(一)
查看>>
[Codeforces 925C]Big Secret
查看>>
处理MVC中默认的Json方法返回时间的问题
查看>>
分布式技术追踪 2018年第十期
查看>>
IDEA中Git的使用
查看>>
War3模型导出
查看>>
java: 列出本机java环境
查看>>
Python内置函数(19)——eval
查看>>
怎样录制屏幕并将结果保存为Gif
查看>>
别名设置 alias
查看>>
练习3.34
查看>>
oracle加减操作
查看>>