长沙理工大学第十二届ACM大赛-重现赛 G - 跑路ing
题目描述
输入描述:
多组输入,保证绝大部分为小数据。
每组输入第一行n m(1<=n<=100,1<=m<=10000),表示n个点m条有向边。
接下来m行,每行u v(1<=u,v<=n),表示有一条有向边从u连向v
输出描述:
算出vigoss18在所有位置的概率,并输出其中的最大值即可。
你的答案与标准答案的误差应保持在1e-6以内。
输入
3 3
1 2
2 3
3 1
输出
0.333333333
题解
$dp$。
$dp[i][j]$表示走$i$步,停在$j$的概率,$dp[i][j]$可以从$dp[i-1][*]$得到,拿矩阵快速幂跑跑就能得到比较高的精度。
#include <bits/stdc++.h>
using namespace std; const int maxn = 100 + 10;
int g[maxn][maxn];
int out[maxn];
int n, m; struct M {
int r, c;
double a[maxn][maxn];
}; M mul(const M &a, const M &b) {
M res;
res.r = a.r;
res.c = b.c;
for(int i = 1; i <= res.r; i ++) {
for(int j = 1; j <= res.c; j ++) {
res.a[i][j] = 0;
for(int k = 1; k <= a.c; k ++) {
res.a[i][j] = res.a[i][j] + a.a[i][k] * b.a[k][j];
}
}
}
return res;
} int main() {
while(~scanf("%d%d", &n, &m)) {
for(int i = 1; i <= n; i ++) {
out[i] = 0;
for(int j = 1; j <= n; j ++) {
g[i][j] = 0;
}
}
while(m --) {
int u, v;
scanf("%d%d", &u, &v);
g[u][v] ++;
out[u] ++;
} M A;
A.r = n;
A.c = n;
for(int i = 1; i <= n; i ++) {
for(int j = 1; j <= n; j ++) {
if(i == j) A.a[i][j] = 1.0;
else A.a[i][j] = 0.0;
}
} M B;
B.r = 1;
B.c = n;
for(int j = 1; j <= n; j ++) {
if(j == 1) B.a[1][j] = 1.0;
else B.a[1][j] = 0.0;
} M C;
C.r = n;
C.c = n;
for(int j = 1; j <= n; j ++) {
for(int i = 1; i <= n; i ++) {
C.a[i][j] = 0.0;
// i -> j
if(i == j) {
C.a[i][j] = 1.0 / (out[i] + 1);
} else {
C.a[i][j] = 1.0 * g[i][j] / (out[i] + 1);
}
}
} int b = 0x7FFFFFFF;
while(b) {
if(b & 1) B = mul(B, C);
b = b / 2;
C = mul(C, C);
}
A = mul(A, B); double ans = 0.0;
for(int j = 1; j <= n; j ++) {
ans = max(ans, A.a[1][j]);
}
printf("%.8f\n", ans); }
return 0;
}
长沙理工大学第十二届ACM大赛-重现赛 G - 跑路ing的更多相关文章
- 长沙理工大学第十二届ACM大赛-重现赛 J 武藏牌牛奶促销
链接:https://ac.nowcoder.com/acm/contest/1/J 来源:牛客网 武藏牌牛奶促销 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 131072K,其他 ...
- 长沙理工大学第十二届ACM大赛-重现赛I 主持人的烦恼 (sort)
链接:https://ac.nowcoder.com/acm/contest/1/I 来源:牛客网 主持人的烦恼 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 131072K,其他语 ...
- 长沙理工大学第十二届ACM大赛-重现赛 D 小M和天平 (01背包)
链接:https://ac.nowcoder.com/acm/contest/1/D 来源:牛客网 小M和天平 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/C++ 131072K,其他语言 ...
- 长沙理工大学第十二届ACM大赛-重现赛C 安卓图案解锁 (模拟)
链接:https://ac.nowcoder.com/acm/contest/1/C来源:牛客网 安卓图案解锁 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 131072K,其他语言 ...
- 长沙理工大学第十二届ACM大赛-重现赛 B 日历中的数字 (实现)
链接:https://ac.nowcoder.com/acm/contest/1/B来源:牛客网 全屏查看题目 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 131072K,其他 ...
- 长沙理工大学第十二届ACM大赛-重现赛 L - 选择困难症
题目描述 小L有严重的选择困难症. 早上起床后,需要花很长时间决定今天穿什么出门. 假设一共有k类物品需要搭配选择,每类物品的个数为Ai,每个物品有一个喜欢值Vj,代表小L对这件物品的喜欢程度. 小L ...
- 长沙理工大学第十二届ACM大赛-重现赛 K - 大家一起来数二叉树吧
题目描述 某一天,Zzq正在上数据结构课.老师在讲台上面讲着二叉树,zzq在下面发着呆. 突然zzq想到一个问题:对于一个n个节点,m个叶子的二叉树,有多少种形态呐?你能告诉他吗? 对于第一组样例的解 ...
- 长沙理工大学第十二届ACM大赛-重现赛
年轮广场 时间限制:1秒 空间限制:131072K 题目描述 在云塘校区,有一个很适合晒太阳的地方————年轮广场 年轮广场可以看成n个位置顺时针围成一个环. 这天,天气非常好,Mathon带着他的小 ...
- 长沙理工大学第十二届ACM大赛-重现赛 大家一起来数二叉树吧 (组合计数)
大意: 求n结点m叶子二叉树个数. 直接暴力, $dp[i][j][k][l]$表示第$i$层共$j$节点, 共$k$叶子, 第$i$层有$l$个叶子的方案数, 然后暴力枚举第$i$层出度为1和出度为 ...
随机推荐
- zoj 3229 Shoot the Bullet(有源汇上下界最大流)
Shoot the Bullethttp://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=3442 Time Limit: 2 Second ...
- Codeforces 450B div.2 Jzzhu and Sequences 矩阵快速幂or规律
Jzzhu has invented a kind of sequences, they meet the following property: You are given x and y, ple ...
- Centos 7 下搭建 Dokuwiki
Centos 7 下搭建 Dokuwiki # Dokuwiki 是php的,所以要先搭建php环境,下载 apache和php,第1.2步下载完,相关的依赖都会下载## 1.下载 httpdyum ...
- <LC刷题一>相加为0的数之leetcode1&2&15&16
--题目导航见页面左上角的悬浮框#目录导航#-- 相似题型导航 1.1 twosum两数之和 || 2.2 3Sum三数之和 || 2.3 3Sum Closest最接近的三数之和 ----- ...
- 【BZOJ】2038: [2009国家集训队]小Z的袜子(hose)
[题意]给定n个数字ai,每次询问一个区间中随机抽选两个数字,数字相同的概率,以分数最简形式输出.n,ai<=50000. [算法]莫队算法 [题解]参考:莫队……讲稿? by Foreseea ...
- JavaScript数据类型和转换
JavaScript数据类型 1.Boolean(布尔) 布尔:(值类型)var b1=true;//布尔类型 2.Number(数字) 数值:(值类型)var n1=3.1415926;//数值类型 ...
- HTML5实现仪表盘、温度计等插件实用源码
- vue使用jsx/axios拦截器设置
最害怕的就是做过的事情,转几天又忘记了:写过的代码,也模模糊糊不知道哪里去了,所以告诉自己最好把每天遇到的问题记录下来,好,开始. 新公司要搭个vue后台框架,所以用了简简单单的 vue+iview+ ...
- E - Travel Cards CodeForces - 847K (思维)
题目链接:https://cn.vjudge.net/contest/272855#problem/E 题目大意:给你n,a,b,k,f.n代表有n次旅行计划,然后a代表一次单程旅行的车费,b代表从下 ...
- git push multiple repo
git remote add xxx https://git.github.com