传送门

A. Creating a Character

设读入的数据分别为 $a,b,c$

对于一种合法的分配,设分了 $x$ 给 $a$

那么有 $a+x>b+(c-x)$,整理得到 $x>(b+c-a)/2$

因为 $x \in [0,c]$ ,所以求一下区间交的大小即可,注意 (b+c-a) 可能小于 0

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
using namespace std;
typedef long long ll;
inline int read()
{
int x=,f=; char ch=getchar();
while(ch<''||ch>'') { if(ch=='-') f=-; ch=getchar(); }
while(ch>=''&&ch<='') { x=(x<<)+(x<<)+(ch^); ch=getchar(); }
return x*f;
}
int T,a,b,c;
int main()
{
T=read();
while(T--)
{
a=read(),b=read(),c=read();
if(b+c-a<) printf("%d\n",c+);
else printf("%d\n",max(c- (b+c-a)/ ,));
}
return ;
}

A

B. Zmei Gorynich

看一眼想到了屠龙勇士

首先如果可以一刀秒了那直接秒了就行

不然设单次最大伤害为 $mx$ ,就是斩杀线,一旦血量低于 $mx$ 就不用管之后会回多少血了

否则只能慢慢磨,设 $d-h$ 最大值为 $G$,那么我们每回合就只能扣 $G$ 的血

直到低于或等于斩杀线,直接斩杀即可,当然如果 $G<=0$ 则无法取胜

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
using namespace std;
typedef long long ll;
inline ll read()
{
ll x=,f=; char ch=getchar();
while(ch<''||ch>'') { if(ch=='-') f=-; ch=getchar(); }
while(ch>=''&&ch<='') { x=(x<<)+(x<<)+(ch^); ch=getchar(); }
return x*f;
}
const ll INF=1e18;
ll T,n,m,mx,G;
struct dat {
ll x,y;
}d[];
int main()
{
T=read();
while(T--)
{
n=read(),m=read(); mx=-INF,G=-INF;
for(int i=;i<=n;i++)
{
d[i].x=read(),d[i].y=read();
mx=max(mx,d[i].x); G=max(G,d[i].x-d[i].y);
}
if(mx>=m) { printf("1\n"); continue; }
if(G<=) { printf("-1\n"); continue; }
printf("%lld\n",(m-mx)/G+((m-mx)%G>)+);
}
return ;
}

B

C. The Number Of Good Substrings

考虑怎样的一段会产生贡献,就是某一位 $1$ 开始往右若干位,然后往左再延伸若干个连续的 $0$

显然往右移动的位数不会大于 $\log m$ ,其中 $m$ 为串长

所以对每一个 $s[i]=1$ 暴力右移,并维护当前位置最多能左移 $t$ 个 $0$,设当前区间 $[i,i+j]$ 的值为 $now$

如果满足 $now-j-1<=t$ 则合法

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<vector>
using namespace std;
typedef long long ll;
inline int read()
{
int x=,f=; char ch=getchar();
while(ch<''||ch>'') { if(ch=='-') f=-; ch=getchar(); }
while(ch>=''&&ch<='') { x=(x<<)+(x<<)+(ch^); ch=getchar(); }
return x*f;
}
const int N=2e5+;
int T,n,a[N];
char s[N];
int Ans;
int main()
{
T=read();
while(T--)
{
scanf("%s",s+); n=strlen(s+); Ans=;
for(int i=;i<=n;i++) a[i]=(s[i]-'');
for(int i=,t=;i<=n;i++)
{
if(!a[i]) { t++; continue; }
int now=;
for(int j=;j<&&i+j<=n;j++)
{
now=(now<<)|a[i+j];
if( now-j-<=t ) Ans++;
}
t=;
}
printf("%d\n",Ans);
}
}

C

D. Coloring Edges

脑子不好用怎么办

首先强行拓扑排序一波看看有没有环,如果没有全部输出 $1$

否则

对于边 $(a,b)$,如果 $a<b$ 染 $1$,否则 $a>b$,染 $2$

这样保证所以纯色路径经过的节点编号单调递增或递减,然后就一定没环....

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<vector>
#include<queue>
using namespace std;
typedef long long ll;
inline int read()
{
int x=,f=; char ch=getchar();
while(ch<''||ch>'') { if(ch=='-') f=-; ch=getchar(); }
while(ch>=''&&ch<='') { x=(x<<)+(x<<)+(ch^); ch=getchar(); }
return x*f;
}
const int N=1e4+;
int n,m,du[N];
vector <int> V[N],ans;
queue <int> Q;
int main()
{
n=read(),m=read(); int x,y;
for(int i=;i<=m;i++)
{
x=read(),y=read();
ans.push_back((x<y)+);
V[x].push_back(y); du[y]++;
}
for(int i=;i<=n;i++) if(!du[i]) Q.push(i);
while(!Q.empty())
{
int x=Q.front(); Q.pop(); int len=V[x].size();
for(int i=;i<len;i++)
{
du[V[x][i]]--;
if(!du[V[x][i]]) Q.push(V[x][i]);
}
}
bool GG=;
for(int i=;i<=n;i++) if(du[i]) { GG=; break; }
if(!GG) { printf("1\n"); for(int i=;i<=m;i++) printf("1 "); }
else
{
printf("2\n");
for(int i=;i<m;i++) printf("%d ",ans[i]);
}
printf("\n");
return ;
}

D

E. Sum Queries?

考虑怎样选最能 "不平衡",发现如果选出两个数,他们某一位都不为 $0$,那么这两个数构成的集合一定不平衡,并且如果选出的两个数他们每一位都最多只有一个不为 $0$,那么一定平衡,所以对于两个数的情况我们只要考虑存在某一位都不为 $0$ 的情况

显然选两个数某一位都不为 $0$,一定比选多个数但是某些数此位为 $0$ 更优,因为我们可以不选此位为 $0$ 的那个数,最终总和还更小

所以只要考虑选两个数的情况

发现如果存在不平衡的方案,那么只要每一位分别考虑不平衡即可,因为就算如果低位进位了影响到当前位,但是低位因为有进位所以低位一定不平衡了,统计答案的时仍然会统计到这种方案

然后就可以开 $9$ 个线段树维护每一位的情况,每一个位的线段树直接维护区间 $[l,r]$ 内此位不为 $0$ 的数的最小值和次小值

然后查询的时候每一位都查询一遍取最小即可,具体看代码咯

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
using namespace std;
typedef long long ll;
inline int read()
{
int x=,f=; char ch=getchar();
while(ch<''||ch>'') { if(ch=='-') f=-; ch=getchar(); }
while(ch>=''&&ch<='') { x=(x<<)+(x<<)+(ch^); ch=getchar(); }
return x*f;
}
const int N=2e5+,INF=1e9+;
int n,m;
struct dat {
int m1,m2;
dat (int a=INF,int b=INF) { m1=a,m2=b; }//注意初始INF
inline dat operator + (const dat &tmp) const {
dat res=*this;
if(tmp.m1<res.m1) res.m2=res.m1,res.m1=tmp.m1;
else res.m2=min(res.m2,tmp.m1);
res.m2=min(res.m2,tmp.m2);
return res;
}
};
struct SegTree {
dat t[N<<],res;
int ql,qr,pos,val;
void ins(int o,int l,int r)
{
if(l==r) { t[o]=dat(val,INF); return; }
int mid=l+r>>;
pos<=mid ? ins(o<<,l,mid) : ins(o<<|,mid+,r);
t[o]=t[o<<]+t[o<<|];
}
void query(int o,int l,int r)
{
if(l>qr||r<ql) return;
if(l>=ql&&r<=qr) { res=res+t[o]; return; }
int mid=l+r>>;
query(o<<,l,mid); query(o<<|,mid+,r);
}
inline void Ins(int x,int y) { pos=x; val=y; ins(,,n); }
inline dat Query(int l,int r) { res=dat(INF,INF); ql=l,qr=r; query(,,n); return res; }
}T[];
int main()
{
n=read(),m=read(); int opt,a,b;
for(int i=;i<=n;i++)
{
a=read();
for(int j=,t=a;j<;j++,t/=)
if(t%) T[j].Ins(i,a);
//此处可以不用Ins(INF) 因为初始就是INF
}
for(int i=;i<=m;i++)
{
opt=read(),a=read(),b=read();
if(opt==)
{
for(int j=,t=b;j<;j++,t/=)
if(t%) T[j].Ins(a,b);
else T[j].Ins(a,INF);//注意要用INF覆盖掉原来的值
continue;
}
int ans=INF*;
for(int j=;j<;j++)
{
dat t=T[j].Query(a,b);
if(t.m2<INF) ans=min(ans,t.m1+t.m2);
}
if(ans<INF*) printf("%d\n",ans);
else printf("-1\n");
}
return ;
}

E

F. Forced Online Queries Problem

神仙题,看一眼以为动态图连通性强制在线

但是 $div2$ 肯定不会这么无聊出这种毒瘤题

$Orz\ Claris$(以下为 Claris 大神 想的)

注意到 $las$ 不是 $1$ 就是 $0$,所以把 $m$ 个操作分成 $2m$ 个操作就可以知道所有可能的操作了

然后就可以离线乱搞,分治

对于当前图 $G$,有 $n$ 点 $m$ 边,$Q$ 询问

如果 $Q=1$ 则到达边界直接暴力,否则

求出当前 $G$  的所有联通块,将 $Q$ 个询问中包含的点所在的联通块保留,其他扔了

此时最多剩下 $2Q$ 个点,设操作后的图为 $G'$

将 $G'$ 和前 $Q/2$ 个操作递归处理,然后回溯后得到前 $Q/2$ 个操作完成的图 $G''$

因为前 $Q/2$ 个操作已经完成,所以知道当前 $las$ 的值

然后再将 $G''$ 和后 $Q/2$ 个操作递归处理

这个神仙算法的复杂度 $n\log n$ (n,m 同阶反正就是这个复杂度)

代码自己参考其他神仙的吧,我是不可能会的

Educational Codeforces Round 72 (Rated for Div. 2) Solution的更多相关文章

  1. Educational Codeforces Round 72 (Rated for Div. 2)-D. Coloring Edges-拓扑排序

    Educational Codeforces Round 72 (Rated for Div. 2)-D. Coloring Edges-拓扑排序 [Problem Description] ​ 给你 ...

  2. 拓扑排序入门详解&&Educational Codeforces Round 72 (Rated for Div. 2)-----D

    https://codeforces.com/contest/1217 D:给定一个有向图,给图染色,使图中的环不只由一种颜色构成,输出每一条边的颜色 不成环的边全部用1染色 ps:最后输出需要注意, ...

  3. Educational Codeforces Round 72 (Rated for Div. 2)

    https://www.cnblogs.com/31415926535x/p/11601964.html 这场只做了前四道,,感觉学到的东西也很多,,最后两道数据结构的题没有补... A. Creat ...

  4. Educational Codeforces Round 72 (Rated for Div. 2) C题

    C. The Number Of Good Substrings Problem Description: You are given a binary string s (recall that a ...

  5. Educational Codeforces Round 72 (Rated for Div. 2) B题

    Problem Description: You are fighting with Zmei Gorynich — a ferocious monster from Slavic myths, a ...

  6. Educational Codeforces Round 72 (Rated for Div. 2) A题

    Problem Description: You play your favourite game yet another time. You chose the character you didn ...

  7. Coloring Edges(有向图环染色)-- Educational Codeforces Round 72 (Rated for Div. 2)

    题意:https://codeforc.es/contest/1217/problem/D 给你一个有向图,要求一个循环里不能有相同颜色的边,问你最小要几种颜色染色,怎么染色? 思路: 如果没有环,那 ...

  8. Educational Codeforces Round 72 (Rated for Div. 2)E(线段树,思维)

    #define HAVE_STRUCT_TIMESPEC#include<bits/stdc++.h>using namespace std;#define BUF_SIZE 100000 ...

  9. Educational Codeforces Round 72 (Rated for Div. 2)C(暴力)

    #define HAVE_STRUCT_TIMESPEC#include<bits/stdc++.h>using namespace std;char s[200007];int a[20 ...

随机推荐

  1. aspose 模板输出

    Dictionary<string, string> dictionnaryBig = new Dictionary<string, string>(); dictionnar ...

  2. [LightOJ1008]Fibsieve`s Fantabulous Birthday 题解

    前言 扫了一眼网上的题解,都是找规律. 估计就我一个蒟蒻在打二分. 题解 设一个" ┐"形为一层. 我们二分查找该数在那一层,然后就可以直接计算它的位置了. 代码 #include ...

  3. Python os模块方法

    os模块提供了大量有用的方法来处理文件和目录.本章节中的代码实例是在 Ubuntu Linux系统上运行来演示. 大多数有用的方法都列在这里 - 编号 方法 描述/说明 1 os.access(pat ...

  4. Elasticsear搭建

    2.1:创建用户: (elasticsearch不能使用root用户) useradd angelpasswd angel 2.2:解压安装包 tar -zxvf elasticsearch-5.5. ...

  5. es6新的数据类型——generator

    todo 一.Generator 函数是 ES6 提供的一种异步编程解决方案,语法行为与传统函数完全不同. 语法上,首先可以把它理解成,Generator 函数是一个状态机,封装了多个内部状态. 执行 ...

  6. Zookeeper集群及配置

    特别提示:本人博客部分有参考网络其他博客,但均是本人亲手编写过并验证通过.如发现博客有错误,请及时提出以免误导其他人,谢谢!欢迎转载,但记得标明文章出处:http://www.cnblogs.com/ ...

  7. MIME 类型,ContentType

    MIME (Multipurpose Internet Mail Extensions) 是描述消息内容类型的因特网标准. MIME 消息能包含文本.图像.音频.视频以及其他应用程序专用的数据. 官方 ...

  8. 三十八、python中反射介绍

    一.反射:根据字符串的形式去对象(某个模块)中去操作成员通过字符串的形式,导入模块通过字符串的形式,去模块中寻找指定的函数,并执行 1.__import__:用于字符串的形似执行导入模块 inp=in ...

  9. windows下eclipse打不开

    报错找不到jre等东西 因为eclipse到不到javaw.exe 将其写入eclipse.ini即可 在eclipse.ini的前面加上 -vm D:\dev_tool\java\jdk1.7.0_ ...

  10. Error: Another program is already listening on a port that one of our HTTP servers is configured to use. Shut this program down first before starting supervisord.

    原文出处: https://blog.csdn.net/hyunbar/article/details/80111947 运行 supervisord -c /etc/supervisor/super ...