CF1214题解
D
因为可以用贡献2把起点终点堵掉,所以答案为0/1/2
0/2简单
1:方格可以理解为分层图,考虑每个能到达终点,起点能到达其的点,标记一下,对角线如果仅存在1则为必经之路
E
\(d_i\le n\),我们先把\(2,4,..,2n\)提出来单独拉一条链,然后乱搞即可
F
咕咕
G
似乎是比较套路的题%%%
单独考虑两行A,B是否有解
无解当且仅当A是B的子集或B是A的子集
\(C=A&B\),则\(A^C\)为\(1\)的位置则,\(A\)为\(1\),\(B\)为\(0\)
\(B\)同理
全局无解当且仅当按1个数排序后,相邻的全为包含关系,故我们可以排序后仅根据相邻的判断答案即可
用bitset优化
#include<bits/stdc++.h>
typedef int LL;
#define mp std::make_pair
inline LL Read(){
LL x(0),f(1); char c=getchar();
while(c<'0' || c>'9'){
if(c=='-') f=-1; c=getchar();
}
while(c>='0' && c<='9'){
x=(x<<3)+(x<<1)+c-'0'; c=getchar();
}return x*f;
}
const LL maxn=2e3+9;
LL n,m,q;
std::bitset<maxn> A[maxn],fac[maxn],C,b1,b2;
struct node{
LL fir,sec;
bool operator < (const node &x)const{
return sec<x.sec || (sec==x.sec && fir<x.fir);//set的比较大小 如出现相对大小则会删去一个
}
};
std::set<node > S;
std::set<std::pair<LL,LL> > ans;
std::set<node >::iterator it1,it2,it3;
std::set<std::pair<LL,LL> >::iterator It1;
inline bool cmp(LL x,LL y){
C=A[x]&A[y];
if(C!=A[x] && C!=A[y]) return true; return false;
}
inline void Modify(LL x,LL cnt,LL ty){
it1=S.find((node){x,cnt}); it2=it1; it2++;
if(it1!=S.begin()){
it3=it1; it3--;
if(ty==-1) ans.erase(mp(it3->fir,it1->fir));
else if(cmp(it3->fir,it1->fir)) ans.insert(mp(it3->fir,it1->fir));
}
if(it2!=S.end()){
if(ty==-1) ans.erase(mp(it1->fir,it2->fir));
else if(cmp(it1->fir,it2->fir)) ans.insert(mp(it1->fir,it2->fir));
}
if(it1!=S.begin() && it2!=S.end()){
--it1;
if(ty==1) ans.erase(mp(it1->fir,it2->fir));
else if(cmp(it1->fir,it2->fir)) ans.insert(mp(it1->fir,it2->fir));
}
}
int main(){
n=Read(); m=Read(); q=Read();
for(LL i=1;i<=n;++i) S.insert((node){i,0});
for(LL i=1;i<=m;++i){
fac[i]=fac[i-1]; fac[i][i]=1;
}
while(q--){
LL x(Read()),l(Read()),r(Read());
LL cnt(A[x].count());
Modify(x,cnt,-1);
S.erase((node){x,cnt});
A[x]^=((fac[r]>>l)<<l);
cnt=A[x].count();
S.insert((node){x,cnt});
Modify(x,cnt,1);
if(ans.empty()) puts("-1");
else{
It1=ans.begin();
LL x(It1->first),y(It1->second);
C=A[x]&A[y];
b1=A[x]^C; b2=A[y]^C;
LL y1(b1._Find_first()),y3(b2._Find_first());
if(x>y) std::swap(x,y);
if(y1>y3) std::swap(y1,y3);
printf("%d %d %d %d\n",x,y1,y,y3);
}
}
return 0;
}
H
神仙题
假设一条链,则按序染色即可
设有三个分叉,链长为\(a,b,c\),设\(a\ge b\ge c\),则\(b+c\ge k\)
证明:\(a\)与\(b\)和\(c\)一个段的位置,\(b\)和\(c\)比可以让其构成一个段,由于重复比无解
注意必须\(k\ge 2\),因为\(k=2\)时不可能一条链由两个分叉组成
寻找解:找到直径,由于其他的点到直径的一端点一定是最远的,故由两端点找次短及三次短判断即可
构造解:直径端点为根遍历,按深度染色
CF1214题解的更多相关文章
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- BZOJ-2561-最小生成树 题解(最小割)
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
- Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
- 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
- 2016ACM青岛区域赛题解
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
- poj1399 hoj1037 Direct Visibility 题解 (宽搜)
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
- 网络流n题 题解
学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...
- CF100965C题解..
求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...
随机推荐
- 深入理解JVM(六) -- GC执行原则和方案
上篇文章中,我们了解了Java虚拟机垃圾回收的思路和策略,这篇文章我们将了解Java是如何实现高效的回收算法的. 我们需要了解,内存回收必须要保证“一致性”,意思就是在执行GC分析的时候,系统看起来要 ...
- 禁止迅雷极速版被强制升级为迅雷x
PS:迅雷极速版( ThunderSpeed1.0.34.360 )下载地址: https://pan.baidu.com/s/1wuBOpNbim5jBru03AfSAVg 按照下面的这个路径去找. ...
- Restful api 返回值重复的问题
Spring boot全家桶前后端分离的项目,在扩充某一个列表形式的返回值时,发现返回值出现了一批的重复. 正常的数据返回: 数值完全一致只是参数名称区分了大小写,如下图: 推测可能是restful格 ...
- stm32 USART_IT_IDLE中断 一帧数据
USART_IT_IDLE中断,是串口收到一帧数据后,发生的中断.也可以叫做一包数据 USART_IT_IDLE和USART_IT_RXNE区别 当接收到1个字节,会产生USART_IT_RXNE中断 ...
- grpc的简单用例 (golang实现)
这个用例的逻辑很简单, 服务器运行一个管理个人信息的服务, 提供如下的四个服务: (1) 添加一个个人信息 注: 对应于Unary RPCs, 客户端发送单一消息给服务器, 服务器返回单一消息 (2) ...
- Crypto模块中的签名算法
因为支付宝当中需要自行实现签名,所以就用到了SHA265和RSA2,将拼接好的信息用私钥进行签名,并进行Base64编码,然后解密就用支付宝回传给用户的公钥解密就ok了,所以我就使用Crypto模块, ...
- Python基础Day1—上
一.计算机基础 CPU:中央处理器,相当于人的大脑:运算中心与控制中心的结合. 内存:临时存储数据,与CPU交互. 硬盘:永久存储数据. 内存的优点:读取速度快 内存的缺点:容量小,造价高,断电数据会 ...
- P,R,F1 等性能度量(二分类、多分类)
总结自<机器学习>周志华 2.3 目录 最常用的是查准率P(precision),查全率R(recall),F1 一.对于二分类问题 二.对于多分类问题 1.macro 2.micro 最 ...
- P2756 飞行员配对方案问题[二分图最大匹配]
题目描述 英国皇家空军从沦陷国征募了大量外籍飞行员.由皇家空军派出的每一架飞机都需要配备在航行技能和语言上能互相配合的2 名飞行员,其中1 名是英国飞行员,另1名是外籍飞行员.在众多的飞行员中,每一名 ...
- 题解 洛谷P5380 【[THUPC2019]鸭棋】
就是一道大模拟. 首先,来解释一下复杂的题意: 给你一些棋子,每个棋都有不同的走法,开局是回归原位. 接下来,题目会给你一个虚拟的走子操作(注意不一定真实),你所需要判断当前操作是否正确.若不正确,输 ...