BZOJ4602: [Sdoi2016]齿轮 DFS 逆元
这道题就是一个DFS,有一篇奶牛题几乎一样。但是这道题卡精度。
这道题网上的另一篇题解是有问题的。取对数这种方法可以被轻松卡。比如1e18 与 (1e9-1)*(1e9+1)取对数根本无法保证不被卡精度。所以我们需要换一个方法。
我们取一个大质数,在这个质数的模意义下进行运算:乘法是乘法,除法变成乘逆元,负数加一个质数。这种方法虽然可能冲突,但是与数据无关。
#include<cstdio>
using namespace std ; struct edge {
int p ;
int a ;
int b ;
edge * next ;
} ; const int p = ; int pow ( int a , int n ) {
int ans = ;
while ( n ) {
if ( n & ) ans *= a , ans %= p ;
a *= a ; a %= p ;
n /= ;
}
return ans ;
} int inv ( const int a ) {
return pow ( a , p - ) ;
} const int MAXN = ;
const int MAXM = ;
int N , M ;
edge E [ MAXM * ] ;
edge * V [ MAXN ] ;
bool vis [ MAXN ] ;
int dis [ MAXN ] ; void read () {
scanf ( "%d%d" , & N , & M ) ;
for ( int i = ; i <= N ; ++ i ) vis [ i ] = V [ i ] = ;
while ( M -- ) {
int s , t , a , b ;
scanf ( "%d%d%d%d" , & s , & t , & a , & b ) ;
edge * const t1= & E [ M * ] ;
t1 -> p = t ;
t1 -> a = a ;
t1-> b = b < ? b + p : b ;
t1-> next = V [ s ] ;
V [ s ] = t1 ;
edge * const f = & E [ M * + ] ;
f -> p = s ;
f -> a = b < ? b + p : b ;
f -> b = a ;
f -> next = V [ t ] ;
V [ t ] = f ;
}
} bool dfs ( const int o ) {
vis [ o ] = true ;
for ( edge * v = V [ o ] ; v ; v = v -> next )
if ( ! vis [ v -> p ] ) {
dis [ v -> p ] = dis [ o ] * v -> a % p * inv ( v -> b ) % p ;
if ( ! dfs ( v -> p ) ) return false ;
} else
if ( dis [ v -> p ] != dis [ o ] * v -> a % p * inv ( v -> b ) % p )
return false ;
return true ;
} bool solve () {
for ( int i = ; i <= N ; ++ i )
if ( ! vis [ i ] && ( dis [ i ] = , ! dfs ( i ) ) ) return false ;
return true ;
} int main () {
int T ;
scanf ( "%d" , & T ) ;
for ( int i = ; i <= T ; ++ i ) {
read () ;
printf ( "Case #%d: " , i ) ;
puts ( solve () ? "Yes" : "No" ) ;
}
return ;
}
BZOJ4602: [Sdoi2016]齿轮 DFS 逆元的更多相关文章
- [bzoj4602][Sdoi2016]齿轮——dfs
题目 现有一个传动系统,包含了N个组合齿轮和M个链条.每一个链条连接了两个组合齿轮u和v,并提供了一个传动比x : y.即如果只考虑这两个组合齿轮,编号为u的齿轮转动x圈,编号为v的齿轮会转动y圈.传 ...
- BZOJ4602 Sdoi2016 齿轮 【带权并查集】*
BZOJ4602 Sdoi2016 齿轮 Description 现有一个传动系统,包含了N个组合齿轮和M个链条.每一个链条连接了两个组合齿轮u和v,并提供了一个传动比x : y.即如果只考虑这两个组 ...
- BZOJ 4602: [Sdoi2016]齿轮 dfs
4602: [Sdoi2016]齿轮 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=4602 Description 现有一个传动系统,包 ...
- BZOJ4602 SDOI2016齿轮(搜索)
dfs一遍给每个齿轮随便标个值看是否矛盾就行了. #include<iostream> #include<cstdio> #include<cmath> #incl ...
- bzoj4602 [Sdoi2016]齿轮
传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=4602 [题解] 对于每组齿轮(u, v)连边,权值为y/x(反向边x/y) 那么直接dfs计 ...
- BZOJ4602:[SDOI2016]齿轮(并查集)
Description 现有一个传动系统,包含了N个组合齿轮和M个链条.每一个链条连接了两个组合齿轮u和v,并提供了一个传动比x : y.即如果只考虑这两个组合齿轮,编号为u的齿轮转动x圈,编号为v ...
- BZOJ4602: [Sdoi2016]齿轮(并查集 启发式合并)
题意 题目链接 Sol 和cc的一道题很像啊 对于初始的\(N\)个点,每加一条限制实际上就是合并了两个联通块. 那么我们预处理出\(val[i]\)表示的是\(i\)节点所在的联通块根节点转了\(1 ...
- [Sdoi2016]齿轮
4602: [Sdoi2016]齿轮 Time Limit: 10 Sec Memory Limit: 512 MB Submit: 613 Solved: 324 [Submit][Status ...
- bzoj 4602: [Sdoi2016]齿轮
4602: [Sdoi2016]齿轮 Description 现有一个传动系统,包含了N个组合齿轮和M个链条.每一个链条连接了两个组合齿轮u和v,并提供了一个传动比x : y.即如果只考虑这两个组合 ...
随机推荐
- Apache Maven(四):依赖
依赖管理是Maven的特性之一,它是用户最为熟悉的特性之一,也是Maven擅长的领域之一.管理单个项目的依赖并没有太大困难,但是当您开始处理由数十或数百个模块组成的多模块项目和应用程序时,Maven可 ...
- libpng的使用
zlib 适用于数据压缩的函式库,由Jean-loup Gailly (负责compression)和 Mark Adler (负责decompression)开发. zlib被设计成一个免费的.通用 ...
- while else
count = 0 while count <= 5 : count += 1 if count == 3:pass print("Loop",count) else: pr ...
- Python基础教程学记(1)
引言 Python是什么?——Python是一种面向对象的解释性高级编程语言,具有动态语义.这句话的要点在于,Python是一种知道如何不妨碍你编写程序的编程语言.它让你能够毫无困难地实现所需的功能, ...
- ruby Encoding
一. 查看ruby支持的编码 Encoding.name_list 二. 搜索编码 Encoding.find('US-ASCII') #=> US-ASCII,不存在则抛出异常 三. __EN ...
- JavaSE基础复习---2---2018/9/28
目录: 1.数据类型 2.变量 3.数组 1.数据类型 谈到java的数据类型,必须知道java是强类型语言.首先,每个变量有类型,每个表达式有类型,而且每种类型是严格定义的.其次,所有的数值传递,不 ...
- Python3 使用基本循环实现多级目录(思路)
一.多级目录设计: 1. 通过循环的方式显示菜单和进入菜单 2. 设置标志位以提供回退上一层菜单 2. 设置标志位以提供退出程序 二.注意要点: 1. 菜单样式,层次关系不要弄混乱 2. 当输入错误时 ...
- java 解析xml 多命名空间问题
先贴段有命名空间的xml吧.. <feed xmlns:im="http://itunes.apple.com/rss" xmlns="http://www.w3. ...
- java Vector向量
9.3.4 Vector向量 [专业IT培训机构,真正零首付入学www.bjsxt.com] Vector底层是用数组实现的List,相关的方法都加了同步检查,因此“线程安全,效率低”. 比如,ind ...
- 完整的vue+vuex+api-router+database请求流程