解题思路

用2-SAT的思路将题目转化为:已知\(n\)个二元组\(<x,y>\),可以算出有多少属于不同二元组的元素\((a,b)\)存在冲突,要在每个二元组\(<x,y>\)中选择选择一个元素,且要尽可能的少选\(y\),问是否可以选取\(n\)个两两不相互矛盾的元素,若可以输出选取方案。

经过简单的推导可以得到,对于\(<x_i,y_i>\)和\(<x_j,y_j>\)

  • 若\(x_ix_j\)(不)冲突,则\(y_iy_j\)(不)冲突
  • 若\(x_iy_j\)(不)冲突,则\(y_ix_j\)(不)冲突

继续用2-SAT的思路,并结合上面的性质:

  • 若\(x_i\)仅和\(x_j\)冲突,则从\(x_i\)向\(y_j\)连一条边,从\(x_j\)向\(y_i\)连一条边;
  • 若\(x_i\)仅和\(y_j\)冲突,则从\(x_i\)向\(x_j\)连一条边,从\(y_i\)向\(y_j\)连一条边;
  • 若都不冲突则不连边;
  • 若都冲突则无解。

这样一来,我们得到了一个或多个联通块,根据之前推导的性质,对于第\(i\)个二元组,如果\(i\)的选取方法确定了,那么相同联通块里的选取方法也就都确定了,再加上不同联通块之间是互不影响的,我们只需要对每个联通块贪心的选取\(y\)少的方案,然后把所有联通块的答案加起来就是最终的答案了。

跑Tarjan缩点或者并查集缩点维护一下就没了。

AC代码

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=110;
int n,m,k;
ll a[55],b[55]; char s[55]; int fa[N],sz[N]; bool vis[N];
int find(int x){return fa[x]==x?x:(fa[x]=find(fa[x]));}
void merge(int x,int y){
x=find(x); y=find(y);
if(x!=y){sz[y]+=sz[x];fa[x]=y;}
} inline int getsame(ll x){
int cnt=0;
while(x){cnt++;x-=x&(-x);}
return m-cnt;
} void solve(){
for(int i=1;i<=n;i++){
for(int j=i+1;j<=n;j++){
bool c1=false,c2=false;
if(getsame(a[i]^a[j])>=k)c1=true;
if(getsame(a[i]^b[j])>=k)c2=true;
if(c1 && c2)continue;
if(!c1 && !c2){printf("-1\n");return;}
if(c2)merge(i,j+n),merge(i+n,j);
if(c1)merge(i,j),merge(i+n,j+n);
}
}
vector<int>ans;
for(int i=1;i<=n;i++){
int fi=find(i),fin=find(i+n);
if(fi==fin){printf("-1\n");return;}
if(vis[fi])continue;
if(vis[fin]){ans.push_back(i);continue;}
if(sz[fi]>sz[fin]){vis[fin]=true;ans.push_back(i);}
else vis[fi]=true;
}
printf("%d\n",(int)ans.size());
for(int i:ans)printf("%d ",i); puts("");
} int main()
{
int T;
scanf("%d",&T);
while(T--){
scanf("%d %d %d",&n,&m,&k);
for(int i=1;i<=2*n;i++)fa[i]=i, sz[i]=(i>n?1:0), vis[i]=false;
for(int i=1;i<=n;i++){
scanf("%s",s); a[i]=0; b[i]=0;
for(int j=0;s[j];j++)a[i]*=2, a[i]+=s[j]-'0';
reverse(s,s+m);
for(int j=0;s[j];j++)b[i]*=2, b[i]+=s[j]-'0';
}
solve();
}
return 0;
}

Codeforces 1250E The Coronation的更多相关文章

  1. python爬虫学习(5) —— 扒一下codeforces题面

    上一次我们拿学校的URP做了个小小的demo.... 其实我们还可以把每个学生的证件照爬下来做成一个证件照校花校草评比 另外也可以写一个物理实验自动选课... 但是出于多种原因,,还是绕开这些敏感话题 ...

  2. 【Codeforces 738D】Sea Battle(贪心)

    http://codeforces.com/contest/738/problem/D Galya is playing one-dimensional Sea Battle on a 1 × n g ...

  3. 【Codeforces 738C】Road to Cinema

    http://codeforces.com/contest/738/problem/C Vasya is currently at a car rental service, and he wants ...

  4. 【Codeforces 738A】Interview with Oleg

    http://codeforces.com/contest/738/problem/A Polycarp has interviewed Oleg and has written the interv ...

  5. CodeForces - 662A Gambling Nim

    http://codeforces.com/problemset/problem/662/A 题目大意: 给定n(n <= 500000)张卡片,每张卡片的两个面都写有数字,每个面都有0.5的概 ...

  6. CodeForces - 274B Zero Tree

    http://codeforces.com/problemset/problem/274/B 题目大意: 给定你一颗树,每个点上有权值. 现在你每次取出这颗树的一颗子树(即点集和边集均是原图的子集的连 ...

  7. CodeForces - 261B Maxim and Restaurant

    http://codeforces.com/problemset/problem/261/B 题目大意:给定n个数a1-an(n<=50,ai<=50),随机打乱后,记Si=a1+a2+a ...

  8. CodeForces - 696B Puzzles

    http://codeforces.com/problemset/problem/696/B 题目大意: 这是一颗有n个点的树,你从根开始游走,每当你第一次到达一个点时,把这个点的权记为(你已经到过不 ...

  9. CodeForces - 148D Bag of mice

    http://codeforces.com/problemset/problem/148/D 题目大意: 原来袋子里有w只白鼠和b只黑鼠 龙和王妃轮流从袋子里抓老鼠.谁先抓到白色老鼠谁就赢. 王妃每次 ...

随机推荐

  1. Python爬取招聘网站数据,给学习、求职一点参考

    1.项目背景 随着科技的飞速发展,数据呈现爆发式的增长,任何人都摆脱不了与数据打交道,社会对于“数据”方面的人才需求也在不断增大.因此了解当下企业究竟需要招聘什么样的人才?需要什么样的技能?不管是对于 ...

  2. Nginx介绍,安装,配置

    引言 为什么要学习Nginx 问题一: 客户端到底要将请求发送给哪台服务器? 问题二: 如果所有客户端的请求都发送给了服务器1,那另一台岂不是废了 问题三: 客户端发送的请求可能是申请动态资源的,也可 ...

  3. 将Asp.Net Core3.1项目,使用Docker 部署到Centos 8

    一.准备工具 Win 10 Centos 8 Visual Studio 2019 Docker Desktop  下载地址:https://download.docker.com/win/stabl ...

  4. C#开发笔记,点点细微,处处真情,记录开发中的难言之隐

    该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/956 访问. 概述 本系列文章将会向大家介绍本人实际开发过程中所遇到技术 ...

  5. C#LeetCode刷题之#62-不同路径(Unique Paths)

    目录 问题 示例 分析 问题 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/3680 访问. 一个机器人位于一个 m x ...

  6. C#LeetCode刷题之#686-重复叠加字符串匹配(Repeated String Match)

    问题 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/3963 访问. 给定两个字符串 A 和 B, 寻找重复叠加字符串A ...

  7. 如何实现字符串转换成整数(实现atoi内置函数)?

    题目描述 输入一个由数字组成的字符串,把它转换成整数并输出.例如:输入字符串"123",输出整数123. 给定函数原型int StrToInt(const char *str) , ...

  8. Spring——AOP实现

    Spring实现AOP 1.什么是 AOP AOP (Aspect Orient Programming),直译过来就是 面向切面编程.AOP 是一种编程思想,是面向对象编程(OOP)的一种补充.面向 ...

  9. jQuery的事件与 动画

    什么是事件: 事件的本质是委托. Jquery的 方法: $().css(); $().click(); 等等. 鼠标的事件: 区别在于:mouseover与mouseout再进入或离开后会执行这两个 ...

  10. Unity3D天气系统插件UniStorm插件使用说明

    一.开始使用 下载并导入UniStorm插件就可以进行使用了,该资源可以在Assets Store中搜索并下载,也可以评论我会发给你,该插件功能十分强大,内置25种天气类型,并包含音效,完全可以满足我 ...