Matching In Multiplication

题解:

首先如果一个点的度数为1,那么它的匹配方案是固定的,继而我们可以去掉这一对点。通过拓扑我们可以不断去掉所有度数为1的点。

那么剩下的图中左右各有m个点,每个点度数都不小于2,且左边每个点度数都是2,而右侧总度数是2m,因此右侧只能是每个点度数都是2。这说明这个图每个连通块是个环,在环上间隔着取即可,一共两种方案。

时间复杂度O(n)。

比赛的时候已经想出做法了,然而实现的太慢了,时间不够了,最后看了题解才想到,哦,原来隔着取就好了,我还想着去求匹配,标记取边呢

讲道理,这个时间卡得真紧,我写的挫,用vector居然过不去,改成用数组建边,队列手写才过去

#include<bits/stdc++.h>
#define LL long long
#define P pair<int,int>
using namespace std;
const int mod = 998244353;
const int N = 1e6 + 10;
int read(){
int x = 0;
char c = getchar();
while(c < '0' || c > '9') c = getchar();
while(c >= '0' && c <= '9') x = x * 10 + c - 48, c = getchar();
return x;
}
struct Edge{
int v,w,nxt;
Edge(){};
}ee[N * 2];
int head[N],EN;
int n;
int d[N];
int vis[N];
int cnt;
int e[N];
int Q[N];
void add(int u,int v,int w){
ee[EN].v = v,ee[EN].w = w,ee[EN].nxt = head[u + n];
head[u + n] = EN++;
ee[EN].v = u + n,ee[EN].w = w,ee[EN].nxt = head[v];
head[v] = EN++;
}
void init(){
EN = 0;
for(int i = 1;i <= 2 * n;i++) {
vis[i] = d[i] = 0;
head[i] = -1;
}
}
void dfs(int u,int f){
vis[u] = 1;
bool flag = true;
int p;
for(int i = head[u];~i;i = ee[i].nxt){
if(ee[i].v != f) p = ee[i].w;
if(!vis[ee[i].v]){
e[cnt++] = ee[i].w;
flag = false;
dfs(ee[i].v,u);
}
}
if(flag){
e[cnt++] = p;
}
} int main(){ int T;
T = read();
while(T--){
n = read();
int u,v,w,v1,w1,v2,w2;
init();
for(int i = 1;i <= n;i++){
v1 = read(),w1 = read(),v2 = read(),w2 = read();
d[v1]++,d[v2]++;
add(i,v1,w1);
add(i,v2,w2);
}
int h = 0,t = 0;
LL ans = 1;
for(int i = 1;i <= n;i++){
if(d[i] == 1) Q[t++] = i;
}
while(h < t){
u = Q[h++];
for(int i = head[u];~i;i = ee[i].nxt){
if(vis[ee[i].v]) continue;
ans = ans * ee[i].w % mod, v = ee[i].v;
break;
}
vis[u] = vis[v] = 1;
for(int i = head[v];~i;i = ee[i].nxt){
if(!vis[ee[i].v] && --d[ee[i].v] == 1) Q[t++] = ee[i].v;
}
}
for(int i = 1;i <= n;i++){
if(!vis[i] && d[i] == 2){
cnt = 0;
dfs(i,-1);
LL res1 = 1,res2 = 1;
for(int j = 0;j < cnt;j+=2){
res1 = res1 * e[j] % mod;
res2 = res2 * e[j+1] % mod;
}
ans = ans * (res1 + res2) % mod ;
}
}
printf("%lld\n",ans);
}
return 0;
}

2017 多校4 Matching In Multiplication(二分图)的更多相关文章

  1. HDU 6073 - Matching In Multiplication | 2017 Multi-University Training Contest 4

    /* HDU 6073 - Matching In Multiplication [ 图论 ] | 2017 Multi-University Training Contest 4 题意: 定义一张二 ...

  2. HDU 6073 Matching In Multiplication —— 2017 Multi-University Training 4

    Matching In Multiplication Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 524288/524288 K ( ...

  3. HDU 6073 Matching In Multiplication(拓扑排序)

    Matching In Multiplication Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 524288/524288 K ( ...

  4. hdu6073[dfs+删边] 2017多校4

    题目中对二分图的定义十分特殊, 指的是 U,V两部分中,U的顶点度数必定为2,V中顶点无限制. 题目要求的是 对于所有匹配,该匹配的权值=该匹配中选中的边的边权的乘积,求所有匹配权值之和. 对于V中的 ...

  5. hdu6073 Matching In Multiplication 分析+拓扑序

    Matching In Multiplication Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 524288/524288 K ( ...

  6. 2017 多校5 hdu 6093 Rikka with Number

    2017 多校5 Rikka with Number(数学 + 数位dp) 题意: 统计\([L,R]\)内 有多少数字 满足在某个\(d(d>=2)\)进制下是\(d\)的全排列的 \(1 & ...

  7. 2017 多校5 Rikka with String

    2017 多校5 Rikka with String(ac自动机+dp) 题意: Yuta has \(n\) \(01\) strings \(s_i\), and he wants to know ...

  8. 2017 多校4 Wavel Sequence

    2017 多校4 Wavel Sequence 题意: Formally, he defines a sequence \(a_1,a_2,...,a_n\) as ''wavel'' if and ...

  9. 2017 多校4 Security Check

    2017 多校4 Security Check 题意: 有\(A_i\)和\(B_i\)两个长度为\(n\)的队列过安检,当\(|A_i-B_j|>K\)的时候, \(A_i和B_j\)是可以同 ...

随机推荐

  1. ionic 命令cordova

    安装android platform : ionic platform add android 安装一维码cordova插件 :cordova plugin add https://github.co ...

  2. SpringMVC-实现PUT请求上传文件(转)

    因为在图片上传的时候使用的是二进制的方式上传,所以使用隐藏域进行方法转换方式失效,转方法: https://www.cnblogs.com/morethink/p/6378015.html 可是后来我 ...

  3. Atlas实现mysql主从分离

     可以接受失败,无法接受放弃!加油! 一.介绍Atlas及架构图 Atlas源代码用C语言编写,它对于Web Server相当于是DB,相对于DB相当于是Client,如果把Atlas的逻辑放到Web ...

  4. Linux下常用压缩 解压命令与压缩比率对比

    常用的格式有:tar, tar.gz(tgz), tar.bz2, 不同方式,压缩和解压方式所耗CPU时间和压缩比率也差异也比较大. 1. tar只是打包动作,相当于归档处理,不做压缩:解压也一样,只 ...

  5. 使用CSS隐藏HTML元素的四种常用方法

    CSS隐藏HTML元素的四种常用方法 1.opacity:设置opacity: 0可以使一个元素变得完全透明. 设置的透明度会被子元素继承,而且无法取消. 通常可以使用opacity属性来制作元素的淡 ...

  6. Laravel系列之环境搭建 — VirtualBox+Vagrant+Homestead

    一.为啥需要搭建环境 为了解决环境不统一问题,所以要搭建这么个玩意儿 二.步骤  Laravel对环境有所要求(不使用Homestead情况下),具体参考官网 使用Homestead步骤 1. Hom ...

  7. JZOJ| 5910. DuLiu

    Description          LF是毒瘤出题人中AK IOI2019,不屑于参加NOI的唯一的人.他对人说话,总是满口垃圾题目者也,教人半懂不懂的.因为他姓李,别人便从QQ群上的“毒瘤李F ...

  8. python爬虫:爬取猫眼TOP100榜的100部高分经典电影

    1.问题描述: 爬取猫眼TOP100榜的100部高分经典电影,并将数据存储到CSV文件中 2.思路分析: (1)目标网址:http://maoyan.com/board/4 (2)代码结构: (3) ...

  9. C++基础 namespace register bool

    1. namespace (1)命令空间 C中的命名空间 在C中只有一个全局作用域 C语言中所有全局标识符共享同一个作用域 标识符之间可能发生冲突 C++中提出了命名空间的概念 命令空间将全局作用域分 ...

  10. MySQL 5.7远程连接

    将/etc/mysql/my.cnf中的bind_address那一行注释掉或修改为"bind_address=0.0.0.0": bind_address并没有在/etc/mys ...