\(\mathcal{Description}\)

  给定 \(n\) 个点 \(m\) 条边的无向图,每条边形如 \((u,v,r)\),表示 \(u,v\) 之间有一条阻值为 \(r\Omega\) 的电阻。求 \(S\) 到 \(T\) 的等效电阻。

  \(n\le100\),\(m\le\frac{n(n-1)}2\)。

\(\mathcal{Solution}\)

  • 欧姆定律:通过一段电路 \(AB\) 两端的电流为 \(\frac{\varphi_A-\varphi_B}{R_{AB}}\)。

  • 基尔霍夫电流定律:设流入电流为正,流出电流为负,则任意节点有 \(\sum I=0\)。

  其中 \(\varphi\) 表示电势(本题中可以粗暴地理解作“高度”,想象成水流从高往低流)。对兔子这种初中电学还没学完的蒟蒻极不友好。

  钦定 \(S\) 输出 \(1A\) 的电流,对于每个点,结合上两条定律,有:

\[\sum_{(u,v)\in E}\frac{\varphi_u-\varphi_v}{R_{uv}}=([u=S]-[u-T])A
\]

  但发现如果有解,那么每个 \(\varphi\) 加上同一常数仍是一组解,所以断定存在一个式子与其它 \(n-1\) 个线性相关。随便去掉一个式子,再钦定 \(\varphi_T=0\),就能解出 \(S\) 的电势 \(\varphi_S\)。由于 \(I=\frac{U}R=1A\),所以 \(\varphi_S\) 的数值就是等效电阻的数值。

\(\mathcal{Code}\)

#include <cstdio>
#include <iostream> const int MAXN = 100;
const double EPS = 1e-9;
int n, m, S, T;
double coe[MAXN + 5][MAXN + 5], I[MAXN + 5], U[MAXN + 5]; inline double abs_ ( const double x ) { return x < 0 ? -x : x; } inline void Gauss ( double A[MAXN + 5][MAXN + 5], double* B, double* X ) {
for ( int i = 1; i <= n; ++ i ) {
int p = i;
for ( int j = i + 1; j <= n; ++ j ) {
if ( abs_ ( A[j][i] ) > abs_ ( A[p][i] ) ) {
p = j;
}
}
if ( i ^ p ) std::swap ( A[i], A[p] ), std::swap ( B[i], B[p] );
for ( int j = i + 1; j <= n; ++ j ) {
double d = A[j][i] / A[i][i];
for ( int k = i; k <= n; ++ k ) A[j][k] -= d * A[i][k];
B[j] -= d * B[i];
}
}
for ( int i = n; i; -- i ) {
X[i] = B[i] / A[i][i];
for ( int j = i - 1; j; -- j ) B[j] -= A[j][i] * X[i];
}
} int main () {
freopen ( "electric.in", "r", stdin );
freopen ( "electric.out", "w", stdout );
scanf ( "%d %d %d %d", &n, &m, &S, &T );
for ( int i = 1; i < n; ++ i ) I[i] = ( i == S ) - ( i == T );
for ( int i = 1, u, v, t; i <= m; ++ i ) {
scanf ( "%d %d %d", &u, &v, &t );
double r = 1.0 / t;
if ( u < n ) coe[u][u] += r, coe[u][v] -= r;
if ( v < n ) coe[v][v] += r, coe[v][u] -= r;
}
coe[n][T] = 1;
Gauss ( coe, I, U );
printf ( "%.2f\n", U[S] );
return 0;
}

\(\mathcal{Details}\)

  高消记得换系数行的时候顺便换值啊……这种错查了快 \(2min\) qwq……

Solution -「LOCAL」解析电车的更多相关文章

  1. Solution -「LOCAL」二进制的世界

    \(\mathcal{Description}\)   OurOJ.   给定序列 \(\{a_n\}\) 和一个二元运算 \(\operatorname{op}\in\{\operatorname{ ...

  2. Solution -「LOCAL」大括号树

    \(\mathcal{Description}\)   OurTeam & OurOJ.   给定一棵 \(n\) 个顶点的树,每个顶点标有字符 ( 或 ).将从 \(u\) 到 \(v\) ...

  3. Solution -「LOCAL」过河

    \(\mathcal{Description}\)   一段坐标轴 \([0,L]\),从 \(0\) 出发,每次可以 \(+a\) 或 \(-b\),但不能越出 \([0,L]\).求可达的整点数. ...

  4. Solution -「LOCAL」Drainage System

    \(\mathcal{Description}\)   合并果子,初始果子的权值在 \(1\sim n\) 之间,权值为 \(i\) 的有 \(a_i\) 个.每次可以挑 \(x\in[L,R]\) ...

  5. Solution -「LOCAL」Burning Flowers

      灼之花好评,条条生日快乐(假装现在 8.15)! \(\mathcal{Description}\)   给定一棵以 \(1\) 为根的树,第 \(i\) 个结点有颜色 \(c_i\) 和光亮值 ...

  6. Solution -「LOCAL」画画图

    \(\mathcal{Description}\)   OurTeam.   给定一棵 \(n\) 个点的树形随机的带边权树,求所有含奇数条边的路径中位数之和.树形生成方式为随机取不连通两点连边直到全 ...

  7. Solution -「LOCAL」ZB 平衡树

    \(\mathcal{Description}\)   OurOJ.   维护一列二元组 \((a,b)\),给定初始 \(n\) 个元素,接下来 \(m\) 次操作: 在某个位置插入一个二元组: 翻 ...

  8. Solution -「LOCAL」舟游

    \(\mathcal{Description}\)   \(n\) 中卡牌,每种三张.对于一次 \(m\) 连抽,前 \(m-1\) 次抽到第 \(i\) 种的概率是 \(p_i\),第 \(m\) ...

  9. Solution -「LOCAL」充电

    \(\mathcal{Description}\)   给定 \(n,m,p\),求序列 \(\{a_n\}\) 的数量,满足 \((\forall i\in[1,n])(a_i\in[1,m])\l ...

随机推荐

  1. Go语言系列之自定义实现日志库

    日志库logo gitee地址传送门:https://gitee.com/zhangyafeii/logo 日志库需求分析 1. 支持往不同的地方输出日志 2. 日志分级别 Debug Trace I ...

  2. 正则验证&模态框

    在日常生活中,凡是需要表单验证的都会用到正则验证.下面拿一个简单的带有模态框的正则验证的小demo看一下     <style>         /* 遮罩层 */         .ma ...

  3. JavaScript的执行过程(深入执行上下文、GO、AO、VO和VE等概念)

    JavaScript的执行过程 前言 编写一段JavaScript代码,它是如何执行的呢?简单来说,JS引擎在执行JavaScript代码的过程中需要先解析再执行.那么在解析阶段JS引擎又会进行哪些操 ...

  4. [Raspberry Pi] 入门使用

    今天开始介绍Raspberry Pi(简称RPi,下同)入门的一些基础知识. 第1部分: 安装RPi 1.1  从 http://www.raspberrypi.org/downloads 下载RPi ...

  5. IE8中li添加float属性,中英数字混合BUG

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  6. 508. Most Frequent Subtree Sum

    Given the root of a tree, you are asked to find the most frequent subtree sum. The subtree sum of a ...

  7. 在Django中使用zerorpc

    在Django中使用zerorpc 前言 随着系统架构从集中式单点服务器到分布式微服务方向的迁移,RPC是一个不可回避的话题.如何在系统中引入对开发者友好,性能可靠的RPC服务是一个值得深思的问题. ...

  8. lua之自索引

    Father={ a=100, b=200 } function Father:dis() print(self.a,self.b) end Father.__index=Father Son= { ...

  9. Servlet-斜杠在web中不同意义

    Servlet-斜杠在web中不同意义 在web中 / 斜杠是一种绝对路径 / 斜杠 如果被浏览器解析,得到的地址是:http://ip/port/ / 斜杠 如果被服务器解析,得到的地址是:http ...

  10. Git安装详解

    官网地址: https://git-scm.com/ 查看 GNU 协议,可以直接点击下一步. 选择 Git 安装位置,要求是非中文并且没有空格的目录,然后下一步. Git 选项配置,推荐默认设置,然 ...