热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

bzoj3143游走

Description:一个无向连通图,顶点从1编号到N,边从1编号到M。小Z在该图上进行随机游走,初始时小Z在1号顶点&#

Description:一个无向连通图,顶点从1编号到N,边从1编号到M。 小Z在该图上进行随机游走,初始时小Z在1号顶点,每一步小Z以相等的概率随机选 择当前顶点的某条边,沿着这条边走到下一个顶点,获得等于这条边的编号的分数。当小Z 到达N号顶点时游走结束,总分为所有获得的分数之和。
现在,请你对这M条边进行编号,使得小Z获得的总分的期望值最小。
2≤N≤500

要用高斯消元做。
定义f[i]为期望的到点i的次数,du[i]为点i的度数。那么有
f[i]=∑j与i相邻,j≠nf[j]du[j]+[i==1]f[i] = \sum_{j与i相邻, j\neq n} \frac{f[j]}{du[j]} + [i==1]f[i]=ji,j=ndu[j]f[j]+[i==1]
注意点n只进不出,所以它对其他点的到达次数没有贡献。
点1一开始就有一次到达。

我们现在有了n个n元一次方程。由于这个方程不规则,所以我们只能用数值解法来解这个方程。这里采用高斯消元法。

把f解出来后,就把走每条边的期望次数g[e]求出来。
g[e]=f[e.u]du[e.u]+f[e.v]du[e.v]g[e] = \frac{f[e.u]}{du[e.u]} + \frac{f[e.v]}{du[e.v]}g[e]=du[e.u]f[e.u]+du[e.v]f[e.v]

然后从大到小排个序,从1到m标号即可。

代码:

#include
#include
#include
#include
#include
#include using namespace std;#define MAXN 511
#define MAXM 250011typedef pair<int, int> pii;const double eps &#61; 1e-8;struct GRAPH {vector<vector<int> > s;void ClearEdges() {for (auto& i : s) {i.resize(0);}}void Init(int n) {ClearEdges();s.resize(n &#43; 1);}void AddUndi(int u, int v) {s[u].push_back(v);s[v].push_back(u);}
};struct MATRIX {vector<vector<double> > s;MATRIX() {}MATRIX(size_t a, size_t b) {resize(a, b);}inline size_t row() const {return s.size();}inline size_t col() const {return s.at(0).size();}void resize(size_t a, size_t b) {s.resize(a);for (size_t i &#61; 0; i < a; &#43;&#43;i)s[i].resize(b);}void clear() {for (auto& i : s)for (auto& j : i)j &#61; 0;}void swap_row(size_t i, size_t j, size_t k &#61; 0) {for (; k < col(); &#43;&#43;k)swap(s[i][k], s[j][k]);}//s[i] -&#61; s[j] * dvoid sub_row(size_t i, size_t j, double d, size_t k &#61; 0) {for (; k < col(); &#43;&#43;k)s[i][k] -&#61; d * s[j][k];}//O(n^3)void ToUpper(MATRIX& b) {for (size_t i &#61; 0; i < row(); &#43;&#43;i) {double maxv &#61; fabs(s[i][i]);size_t mr &#61; i;for (size_t j &#61; i &#43; 1; j < row(); &#43;&#43;j) {if (maxv < fabs(s[j][i])) {maxv &#61; fabs(s[j][i]);mr &#61; j;}}swap_row(i, mr, i);b.swap_row(i, mr);if (maxv < eps) continue;for (size_t j &#61; i &#43; 1; j < row(); &#43;&#43;j) {double d &#61; s[j][i] / s[i][i];sub_row(j, i, d, i);b.sub_row(j, i, d);}}}
};//ax &#61; b
MATRIX solve_destory(MATRIX& a, MATRIX& b) {a.ToUpper(b);for (int i &#61; a.row() - 1; i; --i) {assert(fabs(a.s[i][i]) > eps);b.s[i][0] /&#61; a.s[i][i];for (int j &#61; 0; j < i; &#43;&#43;j) {b.s[j][0] -&#61; b.s[i][0] * a.s[j][i];}}return b;
}int main() {GRAPH g;static pii es[MAXM];static double gs[MAXN];int n, m;scanf("%d%d", &n, &m);g.Init(n);for (int i &#61; 0; i < m; &#43;&#43;i) {scanf("%d%d", &es[i].first, &es[i].second);--es[i].first;--es[i].second;}for (int i &#61; 0; i < m; &#43;&#43;i) {g.AddUndi(es[i].first, es[i].second);}MATRIX b(n, 1);b.clear();b.s[0][0] &#61; 1;MATRIX a(n, n);for (int i &#61; 0; i < n; &#43;&#43;i) {a.s[i][i] &#61; 1;for (int v : g.s[i]) {if (v !&#61; n-1)a.s[i][v] &#61; -1.0 / g.s[v].size();}}b &#61; solve_destory(a, b);b.s[n-1][0] &#61; 0;for (int i &#61; 0; i < m; &#43;&#43;i) {gs[i] &#61; b.s[es[i].first][0] / g.s[es[i].first].size() &#43; b.s[es[i].second][0] / g.s[es[i].second].size();}sort(gs, gs &#43; m, greater<double>());double ans &#61; 0;for (int i &#61; 0; i < m; &#43;&#43;i) {ans &#43;&#61; gs[i] * (i &#43; 1);}printf("%.3f\n", ans);return 0;
}


推荐阅读
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • golang常用库:配置文件解析库/管理工具viper使用
    golang常用库:配置文件解析库管理工具-viper使用-一、viper简介viper配置管理解析库,是由大神SteveFrancia开发,他在google领导着golang的 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 深入理解Java泛型:JDK 5的新特性
    本文详细介绍了Java泛型的概念及其在JDK 5中的应用,通过具体代码示例解释了泛型的引入、作用和优势。同时,探讨了泛型类、泛型方法和泛型接口的实现,并深入讲解了通配符的使用。 ... [详细]
  • 本文介绍如何在 Android 中通过代码模拟用户的点击和滑动操作,包括参数说明、事件生成及处理逻辑。详细解析了视图(View)对象、坐标偏移量以及不同类型的滑动方式。 ... [详细]
  • 本文详细介绍了Java中org.neo4j.helpers.collection.Iterators.single()方法的功能、使用场景及代码示例,帮助开发者更好地理解和应用该方法。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • Explore how Matterverse is redefining the metaverse experience, creating immersive and meaningful virtual environments that foster genuine connections and economic opportunities. ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 本文详细解析了Python中的os和sys模块,介绍了它们的功能、常用方法及其在实际编程中的应用。 ... [详细]
  • 本文介绍了在Windows环境下使用pydoc工具的方法,并详细解释了如何通过命令行和浏览器查看Python内置函数的文档。此外,还提供了关于raw_input和open函数的具体用法和功能说明。 ... [详细]
  • 本文由瀚高PG实验室撰写,详细介绍了如何在PostgreSQL中创建、管理和删除模式。文章涵盖了创建模式的基本命令、public模式的特性、权限设置以及通过角色对象简化操作的方法。 ... [详细]
  • 尽管使用TensorFlow和PyTorch等成熟框架可以显著降低实现递归神经网络(RNN)的门槛,但对于初学者来说,理解其底层原理至关重要。本文将引导您使用NumPy从头构建一个用于自然语言处理(NLP)的RNN模型。 ... [详细]
author-avatar
粪想升或_519
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有