题目

给出一个\(2\times n\)个点的二分图的邻接矩阵\(M\)

以及\(m\)个行替换元,\(k\)个列替换元

\(q\)次询问:op u v 表示用第v个行/列替换元去替换矩阵的第u行/列

对初始以及每个操作矩阵输出完全匹配的方案数mod 2 的值

\(n ,m,k \le 10^3 \ , \ q \le 10^5\)

题解

  • 在mod 2 的意义下-1=1,所以完全匹配的方案数=\(det(M)\)

  • bitset 暴力高斯消元\(O(q\frac{n^3}{\omega})\)

  • 询问相当于每次替换一个行或者列,询问矩阵是否满秩

  • 考虑预处理出所有询问的答案

  • 由于替换某一行或者列最多使矩阵的秩加减1

  • 1.如果原矩阵的秩为\(n\):

    由于矩阵满秩,那么对于每一个\(n\)阶向量都可以被线性表示;

    对于每一个询问预处理出这样的表示,可以替换的就是系数为1的位置 

  • 2.如果原矩阵的秩为\(n-1\):

    一定存在并且仅存在一组线性相关的向量,它们的异或和为0向量

    在原来\(n\)个向量中,任意去掉其中的一个都是一个线性无关的组

    对原矩阵消元得到一个基,对一个询问能被线性表出,那么无论如何替换一定不满秩

    否则出现了一个\(n \)个向量的线性无关组,可以替换的就是最开始存在的线性相关那组向量中的任意一个

  • 时间复杂度:\(O(\frac{n^3}{\omega})\)

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. const int N=1010;
  4. typedef bitset<1010> Bit;
  5. int n;
  6. char s[N];
  7. Bit a[N],b[N],p[N],q[N],c,ans[2][100000];
  8. int gauss(Bit*A,Bit*B){
  9. int i=1,j=1;
  10. for(;i<=n&&j<=n;++i,++j){
  11. int pos=i;while(pos<=n&&!A[pos][j])++pos;
  12. if(pos>n){i--;continue;}
  13. if(i!=pos)swap(A[i],A[pos]),swap(B[i],B[pos]);
  14. for(int k=i+1;k<=n;++k)if(A[k][j])A[k]^=A[i],B[k]^=B[i];
  15. }
  16. return i<n?0:i==n?2:1;
  17. }
  18. void get(int fg,Bit*A,Bit*B,Bit C,Bit&re){
  19. int i=1,j=1,pos=0;
  20. for(;i<=n&&j<=n;++i,++j){
  21. if(!A[i][j]){pos=j,i--;continue;}
  22. if(C[j])C^=A[i],re^=B[i];
  23. }
  24. if(fg==2){
  25. if(C.test(pos))re=B[n];
  26. else re.reset();
  27. }
  28. }
  29. int main(){
  30. freopen("maze.in","r",stdin);
  31. freopen("maze.out","w",stdout);
  32. int m,k,Q;scanf("%d",&n);
  33. for(int i=1;i<=n;++i){
  34. scanf("%s",s+1);p[i].set(i);q[i].set(i);
  35. for(int j=1;j<=n;++j)if(s[j]=='1')a[i].set(j),b[j].set(i);
  36. }
  37. int fg=gauss(a,p);gauss(b,q);
  38. //printf("%d:\n",fg);
  39. scanf("%d%d",&m,&k);
  40. for(int i=1;i<=m;++i){
  41. scanf("%s",s+1);c.reset();
  42. for(int j=1;j<=n;++j)if(s[j]=='1')c.set(j);
  43. if(!fg)continue;
  44. get(fg,a,p,c,ans[0][i]);
  45. }
  46. for(int i=1;i<=k;++i){
  47. scanf("%s",s+1);c.reset();
  48. for(int j=1;j<=n;++j)if(s[j]=='1')c.set(j);
  49. if(!fg)continue;
  50. get(fg,b,q,c,ans[1][i]);
  51. }
  52. puts(fg&1?"1":"0");
  53. scanf("%d",&Q);
  54. for(int i=1,op,u,v;i<=Q;++i){
  55. scanf("%d%d%d",&op,&u,&v);
  56. printf("%d\n",ans[op][v].test(u));
  57. }
  58. return 0;
  59. }

【JZOJ5553】【20190625】谜的更多相关文章

  1. pythonchallenge 解谜 Level 0

    解谜地址: http://www.pythonchallenge.com/pc/def/0.html 这题没什么难度,意思就是得到2的38次方的值,然后,替换 http://www.pythoncha ...

  2. pythonchallenge 解谜

    所有代码均使用python 3.5.1 版本 最近在学python,闲来无事觉得这个解谜还挺有意思. 解谜网址  http://www.pythonchallenge.com/ 接下来会写破解教程~

  3. 揭秘JavaScript中谜一样的this

      揭秘JavaScript中谜一样的this 在这篇文章里我想阐明JavaScript中的this,希望对你理解this的工作机制有一些帮助.作为JavaScript程序员学习this对于你的发展有 ...

  4. Activity的"singleTask"之谜

    官方文档称 以这种方式启动的Activity总是属于一个任务的根Activity.果真如此吗?本文将为你解开Activity的"singleTask"之谜. 任务(Task)是个什 ...

  5. Microsoft HoloLens 技术解谜(下)

    读者提问之“HoloLens 的深度传感器有没有可能是基于 TOF?” 先介绍下背景知识,市面上常见的有三种类型的深度传感器: 结构光,这个技术的代表产品是 Kinect 一代,它的传感器芯片用的是 ...

  6. 揭开Linux操作系统的Swap交换区之谜

    揭开Linux操作系统的Swap交换区之谜 Swap,即交换区,除了安装Linux的时候,有多少人关心过它呢?其实,Swap的调整对Linux服务器,特别是Web服务器的性能至关重要.通过调整Swap ...

  7. 解开Android应用程序组件Activity的"singleTask"之谜

    文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/6714543 在Android应用程序中,可以配 ...

  8. Java常见问题3:周期之谜

    谜24 byte是有符号的.范围是-128 - 127. 而0x90是int类型. 比較的时候.不相等. 假设想让其相等,须要进行类型转换:(byte & 0xff) 或者 (byte)0x9 ...

  9. 走进javascript——解开switch之谜

    很早以前就觉得switch很怪异,或者说一直没太理解它,它怪异就怪异在非要给每个语句加上break;不然后面的语句就算不符合条件还是会执行,比如以下这段代码 var num = 2; switch(n ...

随机推荐

  1. Mybatis+MySql 一个标签中执行多条sql语句

    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/cxfly957/article/details/77896590 MySql默认是不支持这种骚操作的 ...

  2. 封装:Cmd命令调用和常用命令

    原文:封装:Cmd命令调用和常用命令 一.Cmd命令调用方法 1.静态方法调用 class Program { static void Main(string[] args) { // Todo :打 ...

  3. Net操作RabbitMQ

    原文:Net操作RabbitMQ 文章目录 1 安装 2 管理界面 3 RabbitMQ的基本概念 4 RabbitMQ的六种工作模式 4.1 简单模式 4.2 工作模式 4.3 发布/订阅模式 4. ...

  4. SUSE12Sp3-安装DockerCE和Docker-compose

    最近在写脚本.发现还是很方便的. Docker下载地址:https://download.docker.com/linux/static/stable/x86_64/ 执行以下脚本即可安装完毕. #! ...

  5. 手机端 关闭当前页面的JS

    JS 代码如下   PS:我找的原代码中, 注释部分是没有注释的,但是调试的时候报错,就注释掉了,因为我只需要微信和支付宝的判定,所以这个地方,就没仔细研究 var isLppzApp = false ...

  6. Scheduling Tasks

    官方文档 https://spring.io/guides/gs/scheduling-tasks/ 官方文档详细介绍了@Scheduled中fixedRate,fixedDelay,cron的用法 ...

  7. 【JVM学习笔记二】垃圾收集器与内存分配策略

    1. 概述 1) GC的历史比Java久远 2) GC需要完成的三件事: | 哪些内存需要回收 | 什么时候回收 | 如何回收 3) Java内存运行时区域各个部分: | Java虚拟机栈.计数器.本 ...

  8. SpringCloud学习第二章-SpringBoot

    SpringCloud 学习前提     SpringCloud是基于SpringBoot构建的,因此他延续了SpringBoot的契约模式以及开发方式.下面将讲到SpringBoot的构建方式. S ...

  9. 【转】如何把变量或者数组定义到SDRAM及任意位置

    我们开发软件的时候,经常会遇到到一个问题,就是内存不够,这个时候就纠结了,怎么办,有两种方法,第一种是扩展内存,外加SRAM或者SDRAM:第二种应该就是优化代码,也就是通常所说的把数组大小减一减,代 ...

  10. springboot+jndi+tomcat配置多数据源

    1.在application.properties中,添加jndi配置,如下图 2.新建dataSourceConfig类 3.dataSourceConfig类详细代码,这里只贴出其中一个,多个数据 ...