P3232 [HNOI2013]游走——无向连通图&&高斯消元
题意
一个无向连通图,顶点从1编号到N,边从1编号到M。 小Z在该图上进行随机游走,初始时小Z在1号顶点,每一步小Z以相等的概率随机选 择当前顶点的某条边,沿着这条边走到下一个顶点,获得等于这条边的编号的分数。当小Z 到达N号顶点时游走结束,总分为所有获得的分数之和。 现在,请你对这M条边进行编号,使得小Z获得的总分的期望值最小。(2<=N<=500)
分析
直接算边的期望会很大,考虑先算点的期望。
设 $E(i)$ 为经过第 $i$ 个点的期望次数,$D(i)$ 为 $i$ 的度数,设 $v$ 为与 $u$ 相连的点,则
$$E(u) = \sum_{v, v \neq n} \frac{E(v)}{D(v)}$$
从而,经过一条边 $(u, v)$ 的期望次数为
$$E(u, v)= \frac{E(u)}{D(u)} + \frac{E(v)}{D(v)}$$
有两点需要注意,结点1期望步数需要加1(可假设有结点0,以概率1转移到结点1);由于到结点 $n$ 就结束了,不要考虑来自 $n$ 的步数。
由于是无向连通图,不用考虑0和无穷大,方程组有唯一的解。
既然求出每条边的期望次数,当然是给次数大的分配小编号,次数小的分配大编号。
#include<bits/stdc++.h>
using namespace std; const int maxn = +;
typedef double Matrix[maxn][maxn]; //要求系数矩阵可逆
//这里的A是增广矩阵,即A[i][n] 是第i个方程右边的常数bi
//运行结束后A[i][n] 是第i个未知数的值
void gauss_elimination(Matrix A, int n)
{
int i, j, k, r; for(i = ;i < n;i++) //消元过程
{
//选绝对值一行r并与第i行交换
r = i;
for(j = i+; j < n;j++)
if(fabs(A[j][i] > fabs(A[r][i]))) r = j;
if(r != i) for(j = ;j <= n;j++) swap(A[r][j], A[i][j]); //与第i+1~n行进行消元
for(k = i+; k < n;k++)
{
double f = A[k][i] / A[i][i];
for(int j = i;j <= n;j++) A[k][j] -= f * A[i][j]; //已经是阶梯型矩阵了,所以从i开始
}
} //回代过程
for(i = n-;i >= ;i--)
{
for(j = i+; j < n;j++)
A[i][n] -= A[j][n] * A[i][j];
A[i][n] /= A[i][i];
}
} void debug_print(Matrix A, int n)
{
for(int i = ;i < n;i++)
for(int j = ;j <= n;j++) printf("%f%c", A[i][j], j == n ? '\n' : ' ');
} int n, m;
vector<int>edges[maxn];
int d[maxn];
Matrix A;
vector<double>e; int main()
{
scanf("%d%d", &n, &m);
for(int i = ;i < m;i++)
{
int u, v;
scanf("%d%d", &u, &v);
u--; v--; //改成从0开始编号
edges[u].push_back(v);
edges[v].push_back(u);
d[u]++; d[v]++;
} //构造方程组
for(int i = ;i <n;i++)
{
A[i][i] = ;
for(int j = ;j <edges[i].size();j++)
if(edges[i][j] != n-) A[i][edges[i][j]] -= 1.0/d[edges[i][j]];
if(i == ) A[i][n] = ;
} //debug_print(A, n); gauss_elimination(A, n); for(int i = ;i < n;i++)
{
for(int j = ;j < edges[i].size();j++)
{
double tmp = ;
if(i != n-) tmp += A[i][n]/d[i];
if(edges[i][j] != n-) tmp += + A[edges[i][j]][n]/d[edges[i][j]]; //不是终点时
e.push_back(tmp);
}
} sort(e.begin(), e.end()); // for(int i = 0;i < e.size();i++) printf("%f ", e[i]);
// printf("\n"); double res = ;
for(int i = ;i < m;i++)
{
res += e[*i]*(m-i); //无向边重复了一次,所以隔一个取一个
}
printf("%.3f\n", res);
}
参考链接:https://www.luogu.org/problemnew/solution/P3232
P3232 [HNOI2013]游走——无向连通图&&高斯消元的更多相关文章
- BZOJ_3143_[Hnoi2013]游走_期望DP+高斯消元
BZOJ_3143_[Hnoi2013]游走_期望DP+高斯消元 题意: 一个无向连通图,顶点从1编号到N,边从1编号到M. 小Z在该图上进行随机游走,初始时小Z在1号顶点,每一步小Z以相等的概率随机 ...
- BZOJ 3143: [Hnoi2013]游走 概率与期望+高斯消元
Description 一个无向连通图,顶点从1编号到N,边从1编号到M.小Z在该图上进行随机游走,初始时小Z在1号顶点,每一步小Z以相等的概率随机选 择当前顶点的某条边,沿着这条边走到下一个顶点,获 ...
- luoguP3232 [HNOI2013]游走 贪心 + 概率期望 + 高斯消元
首先,题目中的无向简单连通图代表着没有自环,重边... 总分的期望 = 每条边的期望之和...................每条边的期望又可以拆成$u \to v$的期望和$v \to u$的期望 ...
- bzoj 3143 [Hnoi2013]游走(贪心,高斯消元,期望方程)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3143 [题意] 给定一个无向图,从1走到n,走过一条边得到的分数为边的标号,问一个边的 ...
- P3232 [HNOI2013]游走 解题报告
P3232 [HNOI2013]游走 题目描述 一个无向连通图,顶点从\(1\)编号到\(N\),边从\(1\)编号到\(M\). 小Z在该图上进行随机游走,初始时小Z在1号顶点,每一步小Z以相等的概 ...
- 洛谷P3232 [HNOI2013]游走(高斯消元+期望)
传送门 所以说我讨厌数学……期望不会高斯消元也不会……好不容易抄好了高斯消元板子被精度卡成琪露诺了…… 首先,我们先算出走每一条边的期望次数,那么为了最小化期望,就让大的期望次数乘上小编号 边的期望次 ...
- 题解 P3232 [HNOI2013]游走
洛谷P3232[NOI2013]游走 题目描述 给定一个 n 个点 m 条边的无向连通图,顶点从 1 编号到 n,边从 1 编号到 m. 小 Z 在该图上进行随机游走,初始时小 Z 在 1 号顶点,每 ...
- 洛谷P3232[HNOI2013]游走
有一个无向简单连通图,顶点从 \(1\) 编号到 \(n\),边从 \(1\) 编号到 \(m\) 小Z在该图上进行随机游走,初始时小Z在\(1\)号顶点,每一步小Z以相等的概率随机选 择当前顶点的某 ...
- [bzoj3143] [洛谷P3232] [HNOI2013] 游走
Description 一个无向连通图,顶点从1编号到N,边从1编号到M. 小Z在该图上进行随机游走,初始时小Z在1号顶点,每一步小Z以相等的概率随机选 择当前顶点的某条边,沿着这条边走到下一个顶点, ...
随机推荐
- MATLAB爬虫爬取股票数据
近年来,大数据盛行,有关爬虫的教程层次不穷.那么,爬虫到底是什么呢? 什么是爬虫? 百度百科是这样定义的: 网络爬虫(又被称为网页蜘蛛,网络机器人,在FOAF社区中间,更经常的称为网页追逐者),是一种 ...
- 安装cnpm出现问题
安装cnpm: 命令行中输入 npm install -g cnpm --registry=http://registry.npm.taobao.org 报:cnpm不是内部命令 解决方法:设置环 ...
- 【Python爬虫案例学习】下载某图片网站的所有图集
前言 其实很简短就是利用爬虫的第三方库Requests与BeautifulSoup. 其实就几行代码,但希望没有开发基础的人也能一下子看明白,所以大神请绕行. 基本环境配置 python 版本:2.7 ...
- 类的练习2——python编程从入门到实践
9-7 管理员: 管理员是一种特殊的用户.编写一个名为Admin的类,并让它继承练习9-3或者9-5的User类.添加一个名为privileges的属性,用于存储一个由字符串(如"can a ...
- robotframework_百度登陆
** Settings *** Library Selenium2Library *** Test Cases *** login Open Browser https://www.baidu.com ...
- redis - redis安装与启动
redis安装 下载redis安装包 wget http://download.redis.io/releases/redis-5.0.7.tar.gz 解压缩 tar -xzf redis-5.0. ...
- Bootstrap 遮罩插件jquery.mloading
使用方法 将jquery.mloading.js和jquery.mloading.css引入到页面,调用: $(element).mLoading({ text:"",//加载文字 ...
- 使用@Async注解创建多线程,自定义线程池
说明 使用@Async注解创建多线程非常的方便,还可以通过配置,实现线程池.比直接使用线程池简单太多.而且在使用上跟普通方法没什么区别,加上个@Async注解即可实现异步调用. 用法 AsyncTas ...
- html5的基本介绍
前言 (1)什么是HTML? 指超文本标记语言(Hyper Text Markup Language); 是用来描述网页的一种语言: 不是编程语言,是一种标记语言: (更多详细内容,百度:https: ...
- unity shader入门(二)语义,结构体,逐顶点光照
下为一个逐顶点漫反射光照shader Shader "study/Chapter6/vertexShader"{ Properties{_Diffuse("Diffuse ...