P3211-[HNOI2011]XOR和路径【高斯消元】

正题

题目链接:https://www.luogu.com.cn/problem/P3211


题目大意

一个nnn个点mmm条边的无向图,从111nnn随机游走。求期望路径异或和。

2≤n≤100,1≤m≤1042\leq n\leq 100,1\leq m\leq 10^42n100,1m104


解题思路

因为是异或的期望,很难直接处理,所以考虑按位考虑每一位是111的概率。

然后nnn很小就是一个很显然的高斯消元了。设fif_ifi表示i∼ni\sim nin111的概率。

fx=1degx(∑x−>y,w=1(1−fy)+∑x−>y,w=0fy)f_x=\frac{1}{deg_x}(\sum_{x->y,w=1}(1-f_y)+\sum_{x->y,w=0}f_y)fx=degx1(x>y,w=1(1fy)+x>y,w=0fy)

时间复杂度O(n3log⁡wi)O(n^3\log w_i)O(n3logwi)


code

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int N=110;
struct node{int to,next,w;
}a[N*N*2];
int n,m,tot,deg[N],ls[N];
double f[N],ans;
void addl(int x,int y,int w){a[++tot].to=y;a[tot].next=ls[x];ls[x]=tot;a[tot].w=w;return;
}
namespace G{double a[N][N],b[N];void init(){for(int i=1;i<=n;i++){for(int j=1;j<=n;j++)a[i][j]=0;b[i]=0;}return;}void solve(double *f){for(int i=1;i<=n;i++){int z=i;for(int j=i+1;j<=n;j++)if(a[j][i]>a[z][i])z=i;swap(a[i],a[z]);swap(b[i],b[z]);double inv=a[i][i];for(int j=i;j<=n;j++)a[i][j]=a[i][j]/inv;b[i]=b[i]/inv;for(int j=i+1;j<=n;j++){double rate=-a[j][i];for(int k=i;k<=n;k++)a[j][k]+=a[i][k]*rate;b[j]+=b[i]*rate;}}for(int i=n-1;i>=1;i--){for(int j=i+1;j<=n;j++)b[i]-=b[j]*a[i][j]/a[j][j];f[i]=b[i];}return;}
};
void solve(int w){G::init();G::a[n][n]=1;for(int x=1;x<n;x++){for(int i=ls[x];i;i=a[i].next){int y=a[i].to;if(a[i].w&w)G::a[x][y]++,G::b[x]++;else G::a[x][y]--;}G::a[x][x]+=deg[x];}G::solve(f);ans+=(double)w*f[1];return;
}
int main()
{scanf("%d%d",&n,&m);for(int i=1;i<=m;i++){int x,y,w;scanf("%d%d%d",&x,&y,&w);deg[x]++;addl(x,y,w);if(x!=y)deg[y]++,addl(y,x,w);}for(int i=0;i<=30;i++)solve(1<<i);printf("%.3lf\n",ans);return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/319192.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【随机】Ghd(CF364D)

正题 luogu CF364D 题目大意 给你一个大小为n的集合&#xff0c;选择一个至少为一半的子集&#xff0c;另其gcd最大 解题思路 由于数字个数很多&#xff0c;考虑随机 随机选10个数&#xff0c;对于每个数&#xff0c;先处理出约数&#xff0c;然后求出所有数和当前数的gcd&…

ASP.NET Core2读写InfluxDB时序数据库

在我们很多应用中会遇到有一种基于一系列时间的数据需要处理&#xff0c;通过时间的顺序可以将这些数据点连成线&#xff0c;再通过数据统计后可以做成多纬度的报表&#xff0c;也可通过机器学习来实现数据的预测告警。而时序数据库就是用于存放管理这种有着时间顺序数据的&…

Nature 新研究发布,GPT 驱动的机器人化学家能够自行设计和进行实验,这对科研意味着什么?

文章目录 前言揭秘Coscientist不到四分钟&#xff0c;设计并改进了程序能力越大&#xff0c;责任越大 前言 有消息称&#xff0c;AI 大模型 “化学家” 登 Nature 能够自制阿司匹林、对乙酰氨基酚、布洛芬&#xff0c;甚至连复杂的钯催化交叉偶联反应&#xff0c;也能完成。 …

珂朵莉的约数

来源&#xff1a;牛客网&#xff1a; 题目描述 珂朵莉给你一个长为n的序列&#xff0c;有m次查询 每次查询给两个数l,r 设s为区间[l,r]内所有数的乘积 求s的约数个数mod 1000000007 输入描述: 第一行两个正整数n,m 第二行一个长为n的序列 之后m行每行两个数l和r 输出描述…

AtCoder Regular Contest 110 E.Shorten ABC——坑

计数渣渣不会啊 下学期学概率论与数理统计不知道会不会提升数数能力 E.Shorten ABC 当B数组确定后&#xff0c;不难发现就是所问问题即从B序列选出A序列的方案数。 等效于那么从mn中选出sn个小球&#xff0c;我们假设多选的n个小球是一个隔板&#xff0c;隔出数组A&#xff0…

【DP】Rotating Substrings(CF1363F)

正题 luogu CF1363F 题目大意 给你一个字符串&#xff0c;你以旋转其中一个字串&#xff08;将最后一给点移到前面&#xff0c;然后整体向后移一位&#xff09;&#xff0c;问最少要多少布可以到目标字符串 解题思路 设 fi,jf_{i,j}fi,j​ 为 sss 中的前 iii 个字符构成 ttt…

P3348-[ZJOI2016]大森林【LCT】

正题 题目链接:https://www.luogu.com.cn/problem/P3348 题目大意 有nnn棵树开始只有一个编号为111的节点且为标记点。mmm次操作要求支持 在l∼rl\sim rl∼r的树中的标记点下面加入一个新的编号的节点将l∼rl\sim rl∼r的树上的标记点改为xxx&#xff08;如果没有节点xxx就不…

SmartCode 常见问题

SmartCode 能干什么&#xff1f;SmartCode IDataSource -> IBuildTask -> IOutput > Build EverythingSmartCode的执行流是 数据源->构建任务->输出&#xff0c;也就是说应用场景非常广泛。从DB读取数据结构&#xff0c;最终生成整个解决方案代码生成器&#x…

[数论]线性筛——约数个数与约数和

参考博客 参考博客 参考博客 这个讲的挺好 预备知识点&#xff1a; 大于1的数n可以分解质因数&#xff1a; np1a1p2a2p3a3*…*pka n的约数的个数是(a11) * (a21) * (a31)…(ak1) 我们先用线性筛来筛出素数 bool mark[maxn]; int prim[maxn]; int cnt; void initial() {cnt0;f…

F. Paper Grading(Trie树+dfs序+二维数点)

F. Paper Grading 大佬题解 一般关于前缀的问题基本都是Trie树。 首先将所给字符串建立一棵Trie树&#xff0c;Trie能够解决一个字符串在一个字符串集合中出现的次数&#xff0c;而查询前缀次数只需要找到Trie树中所给字符末尾的位置&#xff0c;那么其子树中打标记的次数即前…

AT2164-[AGC006C]Rabbit Exercise【差分,倍增,数学期望】

正题 题目链接:https://www.luogu.com.cn/problem/AT2164 题目大意 nnn只兔子编号为1∼n1\sim n1∼n&#xff0c;第iii只在坐标轴xix_ixi​处。然后mmm次跳跃&#xff0c;每次给出aia_iai​&#xff0c;编号为aia_iai​的兔子会等概率的选取ai−1a_{i-1}ai−1​和ai1a_{i1}ai1…

k-substrings(CF961F)

正题 luogu CF961F 题目大意 给你一个字符串T&#xff0c;对于k1~n/2&#xff0c;找到最长的串s&#xff0c;满足s是T左右各删除k个字符构成的字串t的前缀后缀&#xff08;不能是整个字符串&#xff09; 解题思路 不难发现&#xff0c;k的答案左右各删一个字符必定能得到k1的…

全面支持开源,微软加速 Visual Studio 和 Azure DevOps 云升级

在 2018 微软技术暨生态大会&#xff08;Microsoft Tech Summit&#xff09;上&#xff0c;微软宣布围绕 Visual Studio 和 Visual Studio Code 开发平台提供一系列新功能与服务&#xff0c;并对 Azure DevOps 研发云进行整合升级&#xff0c;通过 Visual Studio 开发平台与微软…

求约数个数的和

今天一下午都在研究约数的各种性质。。。 求约数个数的和可以用线性筛的方式&#xff0c;线性求解的方式&#xff0c;这应该是最快的 [数论]线性筛——约数个数与约数和 除此之外还有代码更简便方法&#xff1a; 对应的例题 方法一&#xff1a; #include <iostream> …

I. Space Station(hash记忆化+dp)

《文章》陆游 文章本天成&#xff0c;妙手偶得之。 粹然无疵瑕&#xff0c;岂复须人为。 君看古彝器&#xff0c;巧拙两无施。 汉最近先秦&#xff0c;固已殊淳漓。 胡部何为者&#xff0c;豪竹杂哀丝。 后夔不复作&#xff0c;千载谁与期&#xff1f; I. Space Station 大佬…

HttpClient参观记:.net core 2.2 对HttpClient到底做了什么?

.net core 于 10月17日发布了 ASP.NET Core 2.2.0 -preview3&#xff0c;在这个版本中&#xff0c;我看到了一个很让我惊喜的新特性&#xff1a;HTTP Client Performance Improvements &#xff0c;而且在Linux上性能提升了60% !之前就一直苦于 HttpClient 的糟糕特性&#xff…

【线段树】Serious Business(CF1648D)

正题 luogu CF1648D 题目大意 有一个 3*n 的矩阵&#xff0c;1,3行没有行走限制&#xff0c;对于第2行&#xff0c;有m个区间&#xff0c;覆盖第 i 个区间有 kik_iki​ 的代价&#xff0c;只有覆盖的位置才能走&#xff0c;让你从 (1,1) 走到 (3,n)&#xff08;只能向下和向右…

P6378-[PA2010]Riddle【2-SAT】

正题 题目链接:https://www.luogu.com.cn/problem/P6378 题目大意 给出nnn个点mmm条边的一张无向图&#xff0c;图中有kkk种颜色的点。 要求每种颜色选择一个点作为关键点&#xff0c;满足每条边两边至少有一个关键点 求是否有满足的方案 1≤n,m,k≤1061\leq n,m,k\leq 10^…

后缀数组(讲解)

子串&#xff1a;从原串中选取连续的一段&#xff0c;即子串 空串也是子串 后缀&#xff1a;suf(k)为s(k…n)构成的子串 任何子串都是某个后缀的前缀 最长公共前缀 lcp(suf(i),suf(j)) 问题&#xff1a; 将所有后缀suf(1),suf(2),suf(N)按照字典序从小到大排序 暴力sort N2 …

codeforces1471 D. Strange Definition

D. Strange Definition 大佬题解 由lcm(x,y)xygcd(x,y)lcm(x,y)\frac{xy}{gcd(x,y)}lcm(x,y)gcd(x,y)xy​可知&#xff0c;如果lcm(x,y)gcd(x,y)xygcd2(x,y)\frac{lcm(x,y)}{gcd(x,y)}\frac{xy}{gcd^2(x,y)}gcd(x,y)lcm(x,y)​gcd2(x,y)xy​是完全平方数&#xff0c;那么xyxy…