昨晚听说有教做人场,去补了下玩。

大概我的水平能做个5/6的样子?

(不会二进制Trie啊,我真菜)

A.

傻逼题。大概可以看成向量加法,判断下就好了。

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cmath>
using namespace std;
int x1,x2,yy1,y2,x,y;
int main(){
scanf("%d%d%d%d%d%d",&x1,&yy1,&x2,&y2,&x,&y);
int dx=abs(x1-x2),dy=abs(yy1-y2);
if((abs(dx/x-dy/y)%==)&&(dx%x==)&&(dy%y==))puts("YES");
else puts("NO");
}

B.

找符合要求的最小三元组乘积出现次数。

sort一下随便搞搞就行了。

#include<bits/stdc++.h>
#define N 100010
typedef long long ll;
using namespace std;
ll a[N];int n;ll minv;
inline ll read(){
ll f=,x=;char ch;
do{ch=getchar();if(ch=='-')f=-;}while(ch<''||ch>'');
do{x=x*+ch-'';ch=getchar();}while(ch>=''&&ch<='');
return f*x;
}
int main(){
n=read();
for(int i=;i<=n;i++)a[i]=read();
sort(a+,a+n+);ll cnt=;
for(int i=;i<=n;i++)if(a[i]==a[])cnt++;
if(a[]==a[])cout<<(cnt-)*(cnt-)*cnt/<<endl;
else if(a[]==a[])cout<<(cnt-)*cnt/<<endl;
else cout<<cnt<<endl;
}

C.

第一反应数位dp,反正也可做。

数位记忆化搜索大概也行的样子。

但是可以显然地证明一个性质:x + 1 - sumd(x + 1) ≥ x - sumd(x)

这就满足了一个单调性,按照出题人的想法是可以二分答案。

但是可以直接枚举最大的范围嘛!干嘛非要写个二分答案

而且这么写跑得飞快。

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
ll n,s;
inline bool check(ll x){
ll res=x;
while(res){x-=res%;res/=;}
return x>=s;
}
int main(){
cin>>n>>s;ll maxv=min(n,s+),sum=;
for(ll i=s;i<=maxv;i++)if(check(i))++sum;
cout<<n-maxv+sum<<endl;
}

D.

用单调栈维护一个"一个数向左向右最大可以做max与min能管的距离"

好久不上语文课了表达能力=0

实在不行看官方题解吧。

#include<bits/stdc++.h>
#define N 1000005
#define inf 1000000007
typedef long long ll;
using namespace std;
int n,a[N];
ll ans1,ans2,ans;
stack<int>s1,s2;
inline int read(){
int f=,x=;char ch;
do{ch=getchar();if(ch=='-')f=-;}while(ch<''||ch>'');
do{x=x*+ch-'';ch=getchar();}while(ch>=''&&ch<='');
return f*x;
}
int main(){
n=read();
s1.push();s2.push();
for(int i=;i<=n;i++){
a[i]=read();a[]=;
while(s1.top()&&a[i]<a[s1.top()]){
int top=s1.top();s1.pop();
ans1-=1LL*a[top]*(top-s1.top());
}
ans1+=1LL*a[i]*(i-s1.top());s1.push(i);
a[]=inf;
while(s2.top()&&a[i]>a[s2.top()]){
int top=s2.top();s2.pop();
ans2-=1LL*a[top]*(top-s2.top());
}
ans2+=1LL*a[i]*(i-s2.top());s2.push(i);
ans+=ans2-ans1;
}
cout<<ans<<endl;
}

E.

我太菜了,以前居然没见过这种在二进制字典树上的贪心……

建一个二进制的字典树,然后贪心一下看能不能搞成1就行了。

具体的我日后可能得写个blog介绍下Trie的贪心。

#include<bits/stdc++.h>
#define N 3000005
using namespace std;
int size[N],ch[N][],n,cnt,a,b,type;
inline void ins(int x,int add){
int now=;
for(int i=;i>=;i--){
bool v=((x>>i)&);
if(!ch[now][v])ch[now][v]=++cnt;
now=ch[now][v];
size[now]+=add;
}
}
inline void query(int x,int y){
int ans=,now=,val=;
for(int i=;i>=&&now;i--){
bool xbit=((x>>i)&),ybit=((y>>i)&);
val+=val;
if(ybit){
ans+=size[ch[now][xbit]];now=ch[now][!xbit];
val+=!xbit;
}
else{now=ch[now][xbit];val+=xbit;}
}
printf("%d\n",ans);
}
inline int read(){
int f=,x=;char ch;
do{ch=getchar();if(ch=='-')f=-;}while(ch<''||ch>'');
do{x=x*+ch-'';ch=getchar();}while(ch>=''&&ch<='');
return f*x;
}
int main(){
cnt=;n=read();
while(n--){
int opt=read(),x=read();
if(opt==)ins(x,);
if(opt==)ins(x,-);
if(opt==){
int y=read();
query(x,y);
}
}
}

F.

看到mex突然激动,感觉可能是个DS题。

果然是。

第一反应主席树求一下就好,后来想下,主席树也是没有必要的。

直接线段树维护就行。

类似于取反,求最左节点的操作。

值域过大可以选择动态开点或者离散化。

我就写了个离散化……

类似的分解的操作的题bzoj都有,如果一下子看不懂这篇

可以QQ找我问几个原题。

#include<bits/stdc++.h>
#define N 300005
#define lson (o<<1)
#define rson (o<<1|1)
using namespace std;
typedef long long ll;
ll a[N];
struct Query{ll l,r,opt;}Q[N];
int n,len;
struct Segment_Tree{
int sumv[N<<],addv[N<<],rev[N<<];
inline void pushup(int o){sumv[o]=sumv[lson]+sumv[rson];}
inline void puttag(int o,int l,int r,int add,int re){
if(re){
if(addv[o]==-)rev[o]^=,sumv[o]=r-l+-sumv[o];
else addv[o]^=,sumv[o]=r-l+-sumv[o];
}
else if(add!=-){
rev[o]=;addv[o]=add;sumv[o]=(r-l+)*add;
}
}
inline void pushdown(int o,int l,int r){
int mid=(l+r)>>;
puttag(lson,l,mid,addv[o],rev[o]);
puttag(rson,mid+,r,addv[o],rev[o]);
addv[o]=-;rev[o]=;
}
void build(int o,int l,int r){
if(l==r){addv[o]=-;return;}
int mid=(l+r)>>;
build(lson,l,mid);build(rson,mid+,r);
addv[o]=-;
}
int querymex(int o,int l,int r){
if(l==r)return l;
int mid=(l+r)>>;pushdown(o,l,r);
if(sumv[lson]<mid-l+)return querymex(lson,l,mid);
else return querymex(rson,mid+,r);
}
void change(int o,int l,int r,int ql,int qr,int add,int re){;
if(ql<=l&&r<=qr){puttag(o,l,r,add,re);return;}
int mid=(l+r)>>;pushdown(o,l,r);
if(ql<=mid)change(lson,l,mid,ql,qr,add,re);
if(qr>mid)change(rson,mid+,r,ql,qr,add,re);
pushup(o);
}
}T;
inline ll read(){
ll f=,x=;char ch;
do{ch=getchar();if(ch=='-')f=-;}while(ch<''||ch>'');
do{x=x*+ch-'';ch=getchar();}while(ch>=''&&ch<='');
return f*x;
}
int main(){
n=read();
for(int i=;i<=n;i++){
Q[i].opt=read();Q[i].l=read();Q[i].r=read();
}
a[]=;
for(int i=;i<=n;i++)a[*i-]=Q[i].l,a[*i]=Q[i].r,a[*i+]=Q[i].r+;
sort(a+,a+n*+);
len=;
for(int i=;i<=*n+;++i)if(a[i]!=a[i-]) a[++len]=a[i];
T.build(,,len);
for(int i=;i<=n;i++){
int x=lower_bound(a+,a+len+,Q[i].l)-a,y=lower_bound(a+,a+len+,Q[i].r)-a;
if(Q[i].opt==)T.change(,,len,x,y,,);
if(Q[i].opt==)T.change(,,len,x,y,,);
if(Q[i].opt==)T.change(,,len,x,y,-,);
printf("%lld\n",a[T.querymex(,,len)]);
}
}

啊最后总结下吧。

姿势水平还不够,还得学习一个。

数据结构要学会活学活用,用现有的水平解决一些不是很常规的问题。

dp什么的思维还是不够,要学习一个。

不过这场的外国人居然出了两个DS?

但是可能外国的DS水平不如我国?这个Trie题讲道理可能在国内只有T2的难度吧。

最后一个Segment-Tree可以算奇奇怪怪的常规应用的组合。

所以还是要熟练呀~

Educational Codeforces Round 23 补题小结的更多相关文章

  1. Educational Codeforces Round 27 补题

    题目链接:http://codeforces.com/contest/845 A. Chess Tourney 水题,排序之后判断第n个元素和n+1个元素是不是想等就可以了. #include < ...

  2. cordforce Educational Codeforces Round 47 补题笔记 <未完>

    题目链接 http://codeforces.com/contest/1009 A. Game Shopping 直接模拟即可,用了一个队列来存储账单 #include <iostream> ...

  3. Educational Codeforces Round 12补题 经典题 再次爆零

    发生了好多事情 再加上昨晚教育场的爆零 ..真的烦 题目链接 A题经典题 这个题我一开始推公式wa 其实一看到数据范围 就算遍历也OK 存在的问题进制错误 .. 思路不清晰 两个线段有交叉 并不是端点 ...

  4. Educational Codeforces Round 22 补题 CF 813 A-F

    A The Contest 直接粗暴贪心 略过 #include<bits/stdc++.h> using namespace std; int main() {//freopen(&qu ...

  5. Educational Codeforces Round 23 A-F 补题

    A Treasure Hunt 注意负数和0的特殊处理.. 水题.. 然而又被Hack了 吗的智障 #include<bits/stdc++.h> using namespace std; ...

  6. Educational Codeforces Round 15 套题

    这套题最后一题不会,然后先放一下,最后一题应该是大数据结构题 A:求连续最长严格递增的的串,O(n)简单dp #include <cstdio> #include <cstdlib& ...

  7. Educational Codeforces Round 21 A-E题题解

    A题      ............太水就不说了,贴下代码 #include<string> #include<iostream> #include<cstring& ...

  8. Educational Codeforces Round 23 E. Choosing The Commander trie数

    E. Choosing The Commander time limit per test 2 seconds memory limit per test 256 megabytes input st ...

  9. Educational Codeforces Round 23

    A题 分析:注意两个点之间的倍数差,若为偶数则为YES,否则为NO #include "iostream" #include "cstdio" #include ...

随机推荐

  1. 【bzoj1609】[Usaco2008 Feb]Eating Together麻烦的聚餐 dp

    题目描述 为了避免餐厅过分拥挤,FJ要求奶牛们分3批就餐.每天晚饭前,奶牛们都会在餐厅前排队入内,按FJ的设想所有第3批就餐的奶牛排在队尾,队伍的前端由设定为第1批就餐的奶牛占据,中间的位置就归第2批 ...

  2. Java线程常用方法详解

    线程的常用方法 1.start() : 线程调用该方法将启动线程,使之从新建状态进入就绪队列排队,一旦轮到它来享用CPU资源时,就可以脱离创建它的线程独立开始自己的生命周期了. 2.run(): Th ...

  3. python字典的常用操作

    # dic={[1,2,3]:'123'} #可变类型不能当做字典的key,value可以使用任意类型 # dic={(2,3,4):'123'} # print (dic[(2,3,4)]) #元组 ...

  4. 【刷题】洛谷 P2709 小B的询问

    题目描述 小B有一个序列,包含N个1~K之间的整数.他一共有M个询问,每个询问给定一个区间[L..R],求Sigma(c(i)^2)的值,其中i的值从1到K,其中c(i)表示数字i在[L..R]中的重 ...

  5. [洛谷P2495][SDOI2011]消耗战

    题目大意:有一棵$n(n\leqslant2.5\times10^5)$个节点的带边权的树,$m$个询问,每次询问给出$k(\sum\limits_{i=1}^mk_i\leqslant5\times ...

  6. Python type()函数用途及使用方法

    函数可以做什么 在介绍数据类型的文章中提到过,要怎么样查看对像的数据类型.type()就是一个最实用又简单的查看数据类型的方法.type()是一个内建的函数,调用它就能够得到一个反回值,从而知道想要查 ...

  7. BZOJ2286:[SDOI2011]消耗战——题解

    +++++++++++++++++++++++++++++++++++++++++++ +本文作者:luyouqi233. + +欢迎访问我的博客:http://www.cnblogs.com/luy ...

  8. C++中typedef和#define简介

    本文基于<C++ Primer(第5版)>和网上博客,整理而成. 一.类型别名 类型别名是一个名字,它是某种类型的同义词,有两种方法可用于定义类型别名:typedef.using. 1.关 ...

  9. struts2远程代码执行漏洞汇总整理

    一.S2-001 1.漏洞原理 在默认配置下,如果用户所提交的表单出现验证错误,后端会对用户的输入进行解析处理,然后返回并显示处理结果. 举个例子,当你提交的登录表单为username=xishir& ...

  10. bzoj4773: 负环(倍增floyd)

    浴谷夏令营例题...讲师讲的很清楚,没看题解代码就自己敲出来了 f[l][i][j]表示i到j走2^l条边的最短距离,显然有f[l][i][j]=min(f[l][i][j],f[l-1][i][k] ...