雅礼集训 Day5 T3 题 解题报告
题
题目背景
由于出题人赶时间所以没办法编故事来作为背景。
题目描述
一开始有\(n\)个苹果,\(m\)个人依次来吃苹果,第\(i\)个人会尝试吃\(u_i\)或\(v_i\)号苹果,具体来说分三种情况。
• 1、两个苹果都还在,那么这个人将随便选一个苹果吃了。
• 2、只有一个苹果,那么这个人将吃掉这个苹果。
• 3、都不在了,这个人吃不到苹果就走了。
请问有多少对苹果\((i,j)\)(\(i<j\))满足它们两个都幸存下来的概率\(>0\)。
输入输出格式
输入格式
第一行两个数\(n,m\)。
接下来\(m\)行,每行两个数\(u_i,v_i\)。
输出格式
一个数表示答案。
数据范围
对于测试点 1 ∼ 5: \(n, m \le 20\)。
对于测试点 5 ∼ 8:若把苹果看做点,人看做边,那么会形成一棵树。
对于测试点 9 ∼ 15: \(m \le 400\)。
对于测试点 16 ∼ 25:无特殊限制。
对于所有的数据, \(n \le 400\); \(m \le 5 \times 10^4\)。
牛 逼 题 !
通过手玩,我们可以发现一些简单但没有什么用的结论。
一些很自然的想法是,从第二个点给出的提示着手,或者是对每个点分开统计(毕竟点不多)之类的
但是直接出正解还是很困难,不接触过这种类型基本不可能吧。
考虑一个可存活的苹果集合\(S\)是否可以在\(k\)时间段合法
设\(f_k(S)\)表示\(k\)时间段集合\(S\)是否合法,考虑它的递推式
若\(k\)时间的边为\(E(u,v)\)
则当\(u \in S \ and \ v \in S\)时,\(f_k(S)=0\)
当\(u \in S \ or \ v \in S\)时,\(f_k(S)=f_{k-1}(S \bigcup \{v\}) \ or \ f_{k-1}(S \bigcup \{u\})\)
当\(u \notin S \ and \ v \notin S\)时,\(f_k(S)=f_{k-1}(S)\)
然而这有什么用呢,集合的状态如此多。
我们再次回到题目,要求我们统计点对是否合法,如果对点对\((u,v)\),它的\(f_m(\{u\})=1,f_m(\{v\})=1\)是否意味着它合法呢?
如果这个终止状态合法,那么包含这个终止状态的集合是否需要考虑呢?
第二个问题比较显然,贪心的去想,我们只需要讨论最后的一个最小的集合作为终止状态就一个不会更差了。
如果我们去思考第二个问题,可以发现它是不一定的,于是似乎又陷入了僵橘。
考虑终止状态唯一,想到每次期望\(DP\)都是倒着做的,这个题是否可以从终止状态往回推呢?
考虑回推
初始:\(f_m\{i\}=1\)
当\(u \in S \ and \ v \in S\)时,此时推不回去了,说明没有情况可以推回去
当\(u \in S \ or \ v \in S\)时,\(f_k(S \bigcup \{v\} \ or \ S \bigcup \{u\})=f_{k+1}(S)\)
当\(u \notin S \ and \ v \notin S\)时,\(f_k(S)=f_{k+1}(S)\)
如果这个点在中途都回不去,说明它和谁都配不了
如果这个点搞完了所有的边并且得到了集合\(G\),则集合\(G\)包含的元素是得到它,一定要删去的点集(除了它自己)
于是这里就比较明了了,如果点对\((u,v)\)可以配对,当且仅当两者都可以推回去且推回去的\(G_u \bigcap G_v = \varnothing\)
这里这个集合用\(bitset\)维护一下
复杂度\(O(n^2m/ \omega)\)
Code:
#include <cstdio>
#include <bitset>
const int N=402;
std::bitset <N> g[N];
struct node{int u,v;}e[50010];
int n,m,f[N];
int main()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=m;i++) scanf("%d%d",&e[i].u,&e[i].v);
for(int i=1;i<=n;i++)
{
g[i][i]=1;
for(int j=m;j;j--)
{
int u=e[j].u,v=e[j].v;
if(g[i][u]&&g[i][v]) {f[i]=1;break;}
if(g[i][u]||g[i][v]) g[i][u]=g[i][v]=1;
}
}
int ans=0;
for(int i=1;i<=n;i++)
if(!f[i])
for(int j=i+1;j<=n;j++)
if(!f[j]&&!(g[i]&g[j]).count())
++ans;
printf("%d\n",ans);
return 0;
}
2018.10.5
雅礼集训 Day5 T3 题 解题报告的更多相关文章
- 雅礼集训 Day3 T3 w 解题报告
w 题目背景 \(\frac 14\)遇到了一道水题,双完全不会做,于是去请教小\(\text{D}\).小\(\text{D}\)看了\(0.607^2\)眼就切掉了这题,嘲讽了\(\frac 14 ...
- 雅礼集训 Day1 T3 画作 解题报告
画作 题目描述 小\(\mathrm{G}\)的喜欢作画,尤其喜欢仅使用黑白两色作画. 画作可以抽象成一个\(r\times c\)大小的\(01\)矩阵.现在小\(\mathrm{G}\)构思好了他 ...
- 雅礼集训 Day2 T3 联盟 解题报告
联盟 题目描述 \(\text{G}\) 国周边的 \(n\) 个小国家构成一个联盟以抵御 \(\text{G}\) 国入侵, 为互相支援,他们建立了\(n−1\) 条双向通路, 使得任意两个国家可以 ...
- 「雅礼集训 2017 Day2」解题报告
「雅礼集训 2017 Day2」水箱 我怎么知道这种题目都能构造树形结构. 根据高度构造一棵树,在树上倍增找到最大的小于约束条件高度的隔板,开一个 \(vector\) 记录一下,然后对于每个 \(v ...
- 「雅礼集训 2017 Day1」 解题报告
「雅礼集训 2017 Day1」市场 挺神仙的一题.涉及区间加.区间除.区间最小值和区间和.虽然标算就是暴力,但是复杂度是有保证的. 我们知道如果线段树上的一个结点,\(max=min\) 或者 \( ...
- 雅礼集训 Day3 T2 u 解题报告
u 题目背景 \(\frac 14\) 遇到了一道水题,完全不会做,于是去请教小\(\text{D}\).小\(\text{D}\)看了一眼就切掉了这题,嘲讽了\(\frac 14\)一番就离开了. ...
- 雅礼集训 Day3 T2 v 解题报告
v 题目背景 \(\frac 14\)遇到了一道水题,又完全不会做,于是去请教小\(\text{D}\).小\(\text{D}\)看了\(0.607\)眼就切掉了这题,嘲讽了\(\frac 14\) ...
- 雅礼集训 Day7 T1 Equation 解题报告
Reverse 题目背景 小\(\text{G}\)有一个长度为\(n\)的\(01\)串\(T\),其中只有\(T_S=1\),其余位置都是\(0\).现在小\(\text{G}\)可以进行若干次以 ...
- 雅礼集训 Day6 T2 Equation 解题报告
Equation 题目描述 有一棵\(n\)个点的以\(1\)为根的树,以及\(n\)个整数变量\(x_i\).树上\(i\)的父亲是\(f_i\),每条边\((i,f_i)\)有一个权值\(w_i\ ...
随机推荐
- SpringMVC使用ModelAndView的相对路径和绝对路径的问题
例如:abc/a/a.jsp,想要跳转到根目录的b.jsp 使用 ModelAndView 跳转, 若引用:org.springframework.web.portlet.ModelAndView 这 ...
- 关于Ubuntu 16.04 pip安装Docker-Compose
$ sudo apt-get update 安装pip: $ sudo apt-get install python-pip 卸载旧版本docker-compose: $ sudo pip unins ...
- c#常用数据结构解析【转载】
引用:http://blog.csdn.net/suifcd/article/details/42869341 前言:可能去过小匹夫博客的盆油们读过这篇对于数据结构的总结,但是小匹夫当时写那篇文章的时 ...
- Oracle创建表空间,添加用户及授权
工具/原料 PLSQL 方法/步骤 1.在PLSQL里,用system/css(orcl系统用户)登陆,登陆的时候普通用户登陆选择normal就可以了 2.Oracle用户新增 执行语句 crea ...
- Git的基本命令介绍
Git的安装 进入官网下载系统所需要的版本 官网地址:https://git-scm.com/downloads 点击下载按钮官方网站一般会根据操作系统的自动下载所需要的Git版本. 下载完成后,点 ...
- TI C6000 数据存储处理与性能优化
存储器之于CPU好比仓库之于车间.车间加工过程中的原材料.半成品.成品等均需入出仓库,生产效率再快,如果仓库周转不善,也必然造成生产阻塞.如同仓库需要合理地规划管理一般,数据存储也需要恰当的处理技巧来 ...
- TouTiao开源项目 分析笔记10 实现通用普通文章片段页面
1.RxJava的Observable数据操作符总结 1.1.Map操作符 Map操作符对原始Observable发射的没一项数据应用一个你选择的函数, 然后返回一个发射这些结果的Observable ...
- 17 rest-framework框架的基本组件
序列化 创建一个序列化类 简单使用 开发我们的Web API的第一件事是为我们的Web API提供一种将代码片段实例序列化和反序列化为诸如json之类的表示形式的方式.我们可以通过声明与Django ...
- Ensure that you have installed a JDK (not just a JRE) and configured your JAVA_HOME system variable
编译的时候出现这个,我从svn download下来的代码,运行就报这个错. 当时我还无知的大吼,怎么可能没有配置java_home, 运行了java -version 都显示出来1.8了. 后来,让 ...
- 【Java集合源码剖析】Java集合框架
Java集合工具包位于Java.util包下,包含了很多常用的数据结构,如数组.链表.栈.队列.集合.哈希表等.学习Java集合框架下大致可以分为如下五个部分:List列表.Set集合.Map映射.迭 ...