True Liars[扩展域并查集]

2023-10-31 18:40
文章标签 扩展 查集 true liars

本文主要是介绍True Liars[扩展域并查集],希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

传送门

每个点拆成两个,表示好人或坏人

我们合并集合后,发现存在几组对立的集合

也就是说这个集合和与它对立的集合只能选一个

我们用rt1[i] , rt2[i] 表示第i个集合 和 与第i个集合对立的集合

cnt1,cnt2表示该集合好人的个数

用f[i][j]表示到第i个集合,好人为j的方案数

f[i][j]+=f[i-1][j-cnt1[i]] (f[i-1][cnt1[i-1]!=0)

f[i][j]+=f[i-1][j-cnt2[i]](f[i-1][j-cnt2[i]!=0)

同时记录from[i][j] 表示f[i][j]选的是第i组集合的哪一个集合


#include<cstdio>
#include<cstring>
#include<algorithm>
#define N 305*2*2
using namespace std;
int fa[N],n,p1,p2,rt1[N],rt2[N],tot;
int cnt1[N],cnt2[N],f[N/2][N/2],from[N/2][N/2];
int pre[N],vis[N],ans[N];
void dfs(int i,int j){if(i==0 && j==0) return;if(from[i][j]==1) vis[pre[i]]=1,dfs(i-1,j-cnt1[i]);else vis[pre[i]+p1+p2]=1,dfs(i-1,j-cnt2[i]);
}
int find(int x){return x==fa[x]?x:fa[x]=find(fa[x]);}
void init(){memset(f,0,sizeof(f));memset(from,0,sizeof(from));memset(vis,0,sizeof(vis));memset(ans,0,sizeof(ans));memset(cnt1,0,sizeof(cnt1));memset(cnt2,0,sizeof(cnt2));memset(rt1,0,sizeof(rt1)); tot=0;memset(rt2,0,sizeof(rt2));
}
int main(){while(scanf("%d%d%d",&n,&p1,&p2) && (n+p1+p2)){init();for(int i=1;i<=2*(p1+p2);i++) fa[i]=i;for(int i=1;i<=n;i++){int x,y,x1,y1; char s[5];scanf("%d%d%s",&x,&y,s);x1=find(x+p1+p2),y1=find(y+p1+p2),x=find(x),y=find(y);if(s[0]=='y') {if(x!=y) fa[x]=y;if(x1!=y1) fa[x1]=y1;}if(s[0]=='n'){if(x!=y1) fa[x]=y1;if(x1!=y) fa[x1]=y;}}for(int i=1;i<=p1+p2;i++){if(find(i)==i) rt1[i]=++tot,pre[tot]=i;}for(int i=1;i<=tot;i++) rt2[pre[i]+p1+p2]=i;for(int i=1;i<=p1+p2;i++){cnt1[rt1[find(i)]]++ , cnt2[rt2[find(i)]]++;}f[0][0]=1;for(int i=1;i<=tot;i++)for(int j=min(cnt1[i],cnt2[i]);j<=p1;j++){ if(f[i-1][j-cnt1[i]]) f[i][j]+=f[i-1][j-cnt1[i]] , from[i][j]=1;if(f[i-1][j-cnt2[i]]) f[i][j]+=f[i-1][j-cnt2[i]] , from[i][j]=2; }if(f[tot][p1]!=1) {printf("no\n"); continue;}dfs(tot,p1);for(int i=1;i<=tot;i++) {if(vis[pre[i]]) for(int j=1;j<=p1+p2;j++) if(find(j)==pre[i]) ans[j]=1;if(vis[pre[i]+p1+p2]) for(int j=1;j<=p1+p2;j++) if(find(j)==pre[i]+p1+p2) ans[j]=1;}for(int i=1;i<=p1+p2;i++) if(ans[i]) printf("%d\n",i);printf("end\n");}return 0;
}

 

这篇关于True Liars[扩展域并查集]的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/317333

相关文章

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

poj 1182 并查集 食物链类

题意: 有n只动物,分别编号1....n。所有动物都属于A,B,C中的一种,已知A吃B,B吃C,C吃A。 按顺序给出下面两种共K条信息: 1. x 和 y 属于同一类。 2. x 吃 y 。 然而这些信息可能会出错,有可能有的信息和之前给出的信息矛盾,也有的信息可能给出的 x 和 y 不在n的范围内。 求k条信息中有多少条是不正确的。 解析: 对于每只动物,创建3个元素 i

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

POJ1988带权并查集

M u v 将u所在的堆移动到v所在的堆的上面 C u 求u的下面有多少块 带权并查集 import java.io.BufferedReader;import java.io.InputStream;import java.io.InputStreamReader;import java.io.PrintWriter;import java.math.BigInteger;i

POJ1703带权并查集

D: u v  u与v在不同的集合 A: u v  查询u与v的关系 1)压缩路径过程        fu->root   0  1  u-fu 0                 0  1   1                 1  0 2)合并过程 fu->fv      u->fu   0 1   v->fv 0            1 0 1            0

PHP7扩展开发之数组处理

前言 这次,我们将演示如何在PHP扩展中如何对数组进行处理。要实现的PHP代码如下: <?phpfunction array_concat ($arr, $prefix) {foreach($arr as $key => $val) {if (isset($prefix[$key]) && is_string($val) && is_string($prefix[$key])) {$arr[

PHP7扩展开发之字符串处理

前言 这次,我们来看看字符串在PHP扩展里面如何处理。 示例代码如下: <?phpfunction str_concat($prefix, $string) {$len = strlen($prefix);$substr = substr($string, 0, $len);if ($substr != $prefix) {return $prefix." ".$string;} else

PHP7扩展开发之类型处理

前言 这次,我们将演示如何在PHP扩展中如何对类型进行一些操作。如,判断变量类型。要实现的PHP代码如下: <?phpfunction get_size ($value) {if (is_string($value)) {return "string size is ". strlen($value);} else if (is_array($value)) {return "array si

PHP7扩展开发之依赖其他扩展

前言 有的时候,我们的扩展要依赖其他扩展。比如,我们PHP的mysqli扩展就依赖mysqlnd扩展。这中情况下,我们怎么使用其他扩展呢?这个就是本文讲述的内容。 我们新建立一个扩展,名字叫 demo_dep , 依赖之前的say扩展。 在demo_dep扩展中,我们实现demo_say方法。这个方法调用say扩展的say方法。 代码 基础代码 确保say扩展的头文件正确安装到了php