\(\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. Centos7 文件修改详情

    Centos常规修改信息 记录文件在系统中的意义 /etc/locale.conf ---修改字符集文件 /etc/profile ---修改环境变量

  2. Windwos上Mysql突然出现系统错误3,找不到系统路口

    注:图片如果损坏,点击文章链接:https://www.toutiao.com/i6540869188678844935/ 问题出现: 调试系统时,突然发现数据库连接不上了,打开界面工具也发现连接不上 ...

  3. JSR-303规范

    规范链接 CONSTRAINT 详细信息 @Valid 被注释的元素是一个对象,需要检查此对象的所有字段值 @Null 被注释的元素必须为 null @NotNull 被注释的元素必须不为 null ...

  4. 小程序云开发请求第三方http或https接口

    1.新建http云函数,选中http云函数,右键,打开终端,安装依赖: npm install request-promise 2.http.js引入request-promise用于做网络请求 va ...

  5. Solon Web 开发,二、开发知识准备

    Solon Web 开发 一.开始 二.开发知识准备 三.打包与运行 四.请求上下文 五.数据访问.事务与缓存应用 六.过滤器.处理.拦截器 七.视图模板与Mvc注解 八.校验.及定制与扩展 九.跨域 ...

  6. 从零开始, 开发一个 Web Office 套件 (1): 富文本编辑器

    这是一个系列博客, 最终目的是要做一个基于HTML Canvas 的, 类似于微软 Office 的 Web Office 套件, 包括: 文档, 表格, 幻灯片... 等等. 富文本编辑器 万里长征 ...

  7. gin框架中项目的初始化

    核心知识点 json配置文件解析成结构体 将路由对应的接口抽离到单独的文件中,main函数中直接注册路由即可 项目目录图 项目代码 app.json代码 { "app_name": ...

  8. gin初识

    Gin 是一个用 Go (Golang) 编写的 web 框架. 它是一个类似于 martini 但拥有更好性能的 API 框架, 由于 httprouter,速度提高了近 40 倍. 如果你是性能和 ...

  9. java ++ -- 异或 短路与 短路或 三目条件

    public class Demo { public static void main(String[] args) { int i1 = 12, i2 = 20; int i = (i2++); S ...

  10. django之djangorestframework序列化操作

    只介绍序列化操作:serializers.ModelSerializer 与 serializers.Serializer 使用序列化的目的:将数据序列化成  JSON 对象 当页面上需要动态加载内容 ...