【UOJ#76】【UR #6】懒癌(动态规划)

题面

UOJ

题解

神....神仙题。

先考虑如果是完全图怎么做。。。

因为是完全图,所以是对称的,所以我们只考虑一个有懒癌的人的心路历程。

如果只有一只狗有懒癌:第一天,看了看,似乎其他的狗都没有,但是村子里至少有一只狗有,然后就确定了。

如果有两只狗:第一天,看了看,有一只别的狗有懒癌,不确定;第二天,昨天有懒癌的那只狗还活着,证明他不能确定,所以他还看到了别的狗有懒癌,而除了自己的未知和那个有懒癌的人,别的人的狗都没有懒癌,所以自己的狗有懒癌。

那么递归下去,似乎可以得到如果有\(k\)只狗有懒癌,那么在完全图的情况下就会在第\(k\)天同时开枪。

那么不难发现一切都是在这个人假装自己的狗没有病的前提下,如果他按时听到了枪声,那么他会认为自己的狗没病,否则没有按时听到枪声,他就会认为自己狗病了。那么这个枪声的时间是什么时候呢?显然这个人能够确定的是他所有能够看到的人的狗是否生病,其他的人任意情况都是可能的,那么设\(f[S]\)表示生病状态是开枪时间的最小值,那么这个人会枚举所有的情况,如果在\(max\{f[T]\}\)没有听到枪声,他就会在\(max\{f[T]\}+1\)时刻开枪。这样子直接暴力\(dp\)的复杂度大概是\(O(4^nn)\)左右?

这里打表可以发现当\(U\subset V\)时,\(f[U]\le f[V]\)。这样子就只需要把所有不能确定的全部默认为得了懒癌的,也就是全部看成\(1\)进行转移。

复杂度可以优化到\(O(2^nn)\)。

现在把时间给分开,一种是在有限时间内会开枪的,另外一个种是不会开枪的。考虑一下什么时候不会开枪,也就是一直无法确定的时候,最简单的例子就是只有两个人,他们互相看不见对方,那么永远都不知道时间。考虑构建出补图,即一个人如果看不到另外一个人就连一条边。那么一个不会开枪的情况在补图上表现为一个点数超过\(1\)的强连通分量。这是因为这些人之间的信息无法互相传递,导致信息不完整,所以永远都不会知道。

那么我们可以把这些\(SCC\)给删掉,剩下的部分显然就是一个\(DAG\)。

我们考虑把有懒癌的点给染黑,没有的染白。我们把上面的那个\(dp\)的模型给往这里靠。

这里的过程是:每次可以把一个黑点染白,然后把所有出边染黑。等到所有点都变白了之后,曾经被染黑过的点的个数就是答案。

那么我们回到上面的\(dp\),类比一下这个过程,每次找到一个黑点,一开始默认自己的白的,然后把所有看不到的给变成\(1\),这个过程就是上面的\(dp\)转移。而每次都是在上次的基础上\(+1\)。那么对于每个黑点都要转移出去一次,所以答案和上面的\(DAG\)上的模型一样。

那么我们把题目转化过来了,不难发现这个答案就是黑点点集能够访问到的点的个数。对于第一问考虑答案,显然每个点单独考虑,假设其能够到达这个点的点的个数为\(r\),那么贡献就是\((2^r-1)*2^{n-r}\)。

对于第二问而言,显然只有不存在别的黑点能够到达这个黑点的时候才会被统计,所以答案就是\(2^{n-r}\)。

那么拿\(bitset\)统计就行了。

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<bitset>
  4. using namespace std;
  5. #define MOD 998244353
  6. #define MAX 3030
  7. int n,dg[MAX],bin[MAX],S[MAX],N;
  8. bitset<MAX> a[MAX],g[MAX];
  9. char s[MAX];
  10. int main()
  11. {
  12. scanf("%d",&n);
  13. bin[0]=1;for(int i=1;i<=n;++i)bin[i]=(bin[i-1]*2)%MOD;
  14. for(int i=1;i<=n;++i)
  15. {
  16. scanf("%s",s+1);
  17. for(int j=1;j<=n;++j)
  18. if(i^j)g[i][j]=s[j]=='0',dg[i]+=g[i][j];
  19. }
  20. for(int i=1;i<=n;++i)if(!dg[i])S[++N]=i;
  21. for(int i=1;i<=N;++i)
  22. for(int j=1;j<=n;++j)
  23. if(g[j][S[i]]&&!--dg[j])S[++N]=j;
  24. for(int i=1;i<=N;++i)a[S[i]][S[i]]=1;
  25. for(int i=N;i;--i)
  26. for(int j=1;j<=n;++j)
  27. if(g[S[i]][j])a[j]|=a[S[i]];
  28. int ans1=0,ans2=0,r;
  29. for(int i=1;i<=N;++i)
  30. r=N-a[S[i]].count(),ans1=(ans1+1ll*(bin[N-r]-1)*bin[r])%MOD,ans2=(ans2+bin[r])%MOD;
  31. printf("%d %d\n",ans1,ans2);
  32. return 0;
  33. }

【UOJ#76】【UR #6】懒癌(动态规划)的更多相关文章

  1. 【UOJ#246】套路(动态规划)

    [UOJ#246]套路(动态规划) 题面 UOJ 题解 假如答案的选择的区间长度很小,我们可以做一个暴力\(dp\)计算\(s(l,r)\),即\(s(l,r)=min(s(l+1,r),s(l,r- ...

  2. UOJ #76 -【UR #6】懒癌(思维题)

    UOJ 题面传送门 神仙题. orz czx,czxyyds 首先没有懒癌的狗肯定不会被枪毙,证明显然. 接下来考虑怎样计算一种局面的答案,假设 \(dp_S\) 表示对于有且仅有 \(S\) 中的狗 ...

  3. UOJ #76 【UR #6】懒癌

    确实是一道很不错的题啊. 题目链接 题意 感觉也没什么特别简洁的版本,大家直接看题面吧. 题解 我第一次看到这个类似问题的背景是疯狗,因此下面的题解不自觉的代入了...大家明白意思就好. 我们考虑对于 ...

  4. UOJ 【UR #5】怎样跑得更快

    [UOJ#62]怎样跑得更快 题面 这个题让人有高斯消元的冲动,但肯定是不行的. 这个题算是莫比乌斯反演的一个非常巧妙的应用(不看题解不会做). 套路1: 因为\(b(i)\)能表达成一系列\(x(i ...

  5. NOIP 2016 换教室 (luogu 1850 & uoj 262) - 概率与期望 - 动态规划

    题目描述 对于刚上大学的牛牛来说,他面临的第一个问题是如何根据实际情况申请合适的课程. 在可以选择的课程中,有 2n2n 节课程安排在 nn 个时间段上.在第 ii(1 \leq i \leq n1≤ ...

  6. UOJ #22 UR #1 外星人

    LINK:#22. UR #1 外星人 给出n个正整数数 一个初值x x要逐个对这些数字取模 问怎样排列使得最终结果最大 使结果最大的方案数又多少种? n<=1000,x<=5000. 考 ...

  7. UOJ.52.[UR #4]元旦激光炮(交互 思路)

    题目链接 \(Description\) 交互库中有三个排好序的,长度分别为\(n_a,n_b,n_c\)的数组\(a,b,c\).你需要求出所有元素中第\(k\)小的数.你可以调用至多\(100\) ...

  8. UOJ【UR #12】实验室外的攻防战

    题意: 给出一个排列$A$,问是否能够经过以下若干次变换变为排列$B$ 变换:若${A_i> A_i+1}$,可以${swap(A_i,A_i+1)}$ 考虑一个数字从A排列到B排列连出来的路径 ...

  9. 【UOJ#50】【UR #3】链式反应(分治FFT,动态规划)

    [UOJ#50][UR #3]链式反应(分治FFT,动态规划) 题面 UOJ 题解 首先把题目意思捋一捋,大概就是有\(n\)个节点的一棵树,父亲的编号大于儿子. 满足一个点的儿子有\(2+c\)个, ...

随机推荐

  1. 《DSLR-Quality Photos on Mobile Devices with Deep Convolutional Networks》研读笔记

    <DSLR-Quality Photos on Mobile Devices with Deep Convolutional Networks>研读笔记 论文标题:DSLR-Quality ...

  2. node.js的async和await

    一.async和await是什么 ES2017 标准引入了 async 函数,使得异步操作变得更加方便,async其实本质是Generator函数的语法糖 async表示函数里有异步操作 await表 ...

  3. .net core的服务器模式和工作站模式

    来源:济南小老虎 .NET Core是一个开源通用的开发框架,具有跨平台能力,我们在享受其性能飙升的同时,也面临了一些问题.通过观察 NetCore 程序的线上运行情况发现 ,负载高的情况下应用程序占 ...

  4. Mybatis中动态SQL语句中的parameterType不同数据类型的用法

    Mybatis中动态SQL语句中的parameterType不同数据类型的用法1. 简单数据类型,    此时#{id,jdbcType=INTEGER}中id可以取任意名字如#{a,jdbcType ...

  5. 关于APICloud与DCloud的我的一些看法

    最近因为项目需要,研究了一下市场较为流行的四种移动开发平台:Wex5.APPcan.Dcloud.APICloud,Wex5因为界面UI较为老旧,且语法和js有较大出入,APPcan不开源等缘故,主要 ...

  6. VMware Tools安装方法

    安装VMware Tools的步骤 点击[虚拟机]选项中的[安装VMware Tools],此时在Ubuntu的桌面上就会出现一个光盘图标. 如果之前已经安装过了,[虚拟机]选项中应为[重新安装VMw ...

  7. awk常用命令

    1.统计TCP的连接数量,其中LISTEN多少个,ESTABLISHED多少个. [root@heiniao ~]# netstat -ant Active Internet connections ...

  8. 02-Django项目创建

    第一.Django项目创建 django-admin startproject 项目名 # 注意如果使用虚拟环境,创建应用必须先进入虚拟环境 进入项目目录,tree看项目结构(此时提示tree com ...

  9. MNIST手写数字识别进阶:多层神经网络及应用(1)

    # 一.载入数据 import tensorflow as tf import numpy as np #导入tensorflow提供的读取MNIST的模块 import tensorflow.exa ...

  10. 剑指Offer-26.二叉搜索树与双向链表(C++/Java)

    题目: 输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表.要求不能创建任何新的结点,只能调整树中结点指针的指向. 分析: 创建两个指针,分别指向要处理的当前元素和当前元素的前一个元素.利用中 ...