Mail.Ru Cup 2018 Round 2 Solution
A. Metro
Solved.
题意:
有两条铁轨,都是单向的,一条是从左往右,一条是从右往左,Bob要从第一条轨道的第一个位置出发,Alice的位置处于第s个位置,有火车会行驶在铁轨上,一共有n个站点,1表示火车会在该站点停下,0表示不会,求Bob能否到达地s个位置(到达任意一边即可)
思路:
如果第一条铁轨的第一个位置为0,或者第s个位置的两条铁轨都不停,那么答案显然是$"No"$
再考虑第一条铁轨上所有为1的位置都可以到达
再考虑两条轨道是否有同一个站点都都会停下的,那么就可以到达第二条轨道,并且该站点的左边的会停下的站点都可以到达
再判断一下s站点有没有被标记即可。
#include <bits/stdc++.h>
using namespace std; #define N 1010
int n, s, a[N], b[N];
int vis[N]; bool solve()
{
if (a[] == ) return false;
if (a[s] == && b[s] == ) return false;
for (int i = ; i <= n; ++i) if (a[i]) vis[i] = ;
bool flag = false;
for (int i = n; i >= ; --i)
{
if (a[i] && b[i]) flag = ;
if (flag && b[i]) vis[i] = ;
}
return vis[s];
} int main()
{
while (scanf("%d%d", &n, &s) != EOF)
{
memset(vis, , sizeof vis);
for (int i = ; i <= n; ++i) scanf("%d", a + i);
for (int i = ; i <= n; ++i) scanf("%d", b + i);
puts(solve() ? "YES" : "NO");
}
return ;
}
B. Alice and Hairdresser
Solved,
题意:
Alice有$n根头发,只有长度 > l 的头发才需要减,并且有相邻多根头发的长度都 > l,那么这几根可以一刀剪掉$
现在有两种操作,第一种是询问Alice如果要剪头发,最少需要减几刀,第二种是第$p$根头发增加了$d$的长度。
思路:
头发增加时,如果这根头发已经$ > l 了$ 那么不需要操作
反之,则判断一下,左右两边的头发长度
如果左右两边头发长度都$> l$ 那么下剪刀的次数 - 1 因为左右两边本来是两个连通块,现在连成一个。
如果有一边$ > l$ 有一边不是,那么下剪刀次数不变
如果两边都$ < l$ 那么下剪刀次数+1
#include <bits/stdc++.h>
using namespace std; #define ll long long
#define N 100010
int n, m, res;
ll l, a[N]; int main()
{
while (scanf("%d%d%lld", &n, &m, &l) != EOF)
{
res = ;
for (int i = ; i <= n; ++i)
{
scanf("%lld", a + i);
if (a[i] > l && a[i - ] <= l) ++res;
}
for (int i = , t, p, d; i <= m; ++i)
{
scanf("%d", &t);
if (t == ) printf("%d\n", res);
else
{
scanf("%d%d", &p, &d);
if (a[p] <= l && a[p] + d > l)
{
if (a[p - ] > l && a[p + ] > l) --res;
else if (a[p - ] > l || a[p + ] > l);
else ++res;
}
a[p] += d;
}
}
}
return ;
}
C. Lucky Days
Upsolved.
题意:
定义一个三元组$<l, r, t>$ 表示一个周期为$t$,第$[l, r]$天里面是幸运天,现在给出$Alice 和 Bob$的两个三元组,求两人最长的连续相同的幸运天数。
思路:
考虑两个人的起点之差是 $gcd(ta, tb)$ 用一个人的起点去逼近另一个人的起点,然后求一下答案。
#include <bits/stdc++.h>
using namespace std; #define ll long long
ll la, lb, ra, rb, ta, tb; ll gcd(ll a, ll b)
{
return b ? gcd(b, a % b) : a;
} ll calc(ll la, ll ra, ll lb, ll rb)
{
return max(0ll, min(ra, rb) - max(la, lb) + );
} int main()
{
while (scanf("%lld%lld%lld", &la, &ra, &ta) != EOF)
{
scanf("%lld%lld%lld", &lb, &rb, &tb);
if (la > lb)
{
swap(la, lb);
swap(ra, rb);
swap(ta, tb);
}
ll g = gcd(ta, tb);
ll gap = ra - la;
la += ((lb - la) / g) * g;
ra = la + gap;
printf("%lld\n", max(calc(la, ra, lb, rb), calc(la + g, ra + g, lb, rb)));
}
return ;
}
D. Refactoring
Unsolved.
E. Segments on the Line
Unsolved.
F. Tree and XOR
Upsolved.
题意:
在一棵树种,一共有$n^2$个任意两点间的简单路径异或和,求第k大。
思路:
显然,路上任意两点路径异或和就是两个点到根的异或和再异或
再考虑求第k大,可以二分,然后去找到有多少个比这个数小的数,如果$<= k 那么这个数就可能可以作为答案$
但这样的过程是$O(n{log^n}^2)$,显然不行
但是其实可以直接一位一位考虑,从高位到低位逐位确定,枚举当前为是否为1,如果为1,那么异或后当前为为0的都是比当前数小的数,逐步确定下去即可。
但是注意到,这个过程可以用$01Trie 完成,但是完整的01Trie空间开不下$
又考虑我们每一次确定的时候,只会用到上一层和当前层的状态,所有用滚动数组即可。
#include <bits/stdc++.h>
using namespace std; #define ll long long
#define N 1000010
int n, rt[N], prt[N], ch[N][], num[N], cnt;
ll w[N], k; void init()
{
memset(num, , sizeof num);
memset(ch, , sizeof ch);
} int main()
{
while (scanf("%d%lld", &n, &k) != EOF)
{
init();
for (int i = , p; i <= n; ++i)
{
scanf("%d%lld", &p, w + i);
w[i] ^= w[p];
}
ll res = ;
for (int i = ; i <= n; ++i) rt[i] = prt[i] = ; cnt = ;
for (int s = ; s >= ; --s)
{
for (int i = ; i <= cnt; ++i) ch[i][] = ch[i][] = num[i] = ; cnt = ;
for (int i = ; i <= n; ++i)
{
int id = (w[i] >> s) & ;
if (!ch[rt[i]][id]) ch[rt[i]][id] = ++cnt;
rt[i] = ch[rt[i]][id];
++num[rt[i]];
}
ll sum = ;
for (int i = ; i <= n; ++i)
{
int id = (w[i] >> s) & ;
sum += num[ch[prt[i]][id]];
}
if (sum < k)
{
res |= 1ll << s;
k -= sum;
for (int i = ; i <= n; ++i)
{
int id = (w[i] >> s) & ;
prt[i] = ch[prt[i]][id ^ ];
}
}
else
{
for (int i = ; i <= n; ++i)
{
int id = (w[i] >> s) & ;
prt[i] = ch[prt[i]][id];
}
}
}
printf("%lld\n", res);
}
return ;
}
G. Jellyfish Nightmare
Unsolved.
Mail.Ru Cup 2018 Round 2 Solution的更多相关文章
- Mail.Ru Cup 2018 Round 3 Solution
A. Determine Line Water. #include <bits/stdc++.h> using namespace std; ]; int main() { while ( ...
- Mail.Ru Cup 2018 Round 3 B. Divide Candies
题目链接 分析一下题意可以得到题目要求的是满足下面这个 公式的不同的i,ji,ji,j的方案数; 即(i2+j2)mod   m=0 (n ≤ ...
- Mail.Ru Cup 2018 Round 3
A:签到 #include<iostream> #include<cstdio> #include<cmath> #include<cstdlib> # ...
- Mail.Ru Cup 2018 Round 2
A:阅读理解. #include<iostream> #include<cstdio> #include<cmath> #include<cstdlib> ...
- [codeforces Mail.Ru Cup 2018 Round 3][B Divide Candies ][思维+数学]
https://codeforces.com/contest/1056/problem/B 题意:输入n,m 求((a*a)+(b*b))%m==0的(a,b)种数(1<=a,b<= ...
- [codeforces Mail.Ru Cup 2018 Round 1 D][ xor 操作]
http://codeforces.com/contest/1054/problem/D 题目大意:一个序列a1 a2...an,可以对若干个元素进行取反,使所得的新序列异或和为0的区间个数最多. 题 ...
- Mail.Ru Cup 2018 Round 1
A. Elevator or Stairs? 签. #include <bits/stdc++.h> using namespace std; ]; int main() { while ...
- Mail.Ru Cup 2018 Round 1 virtual participate记
因为睡过了只好vp. A:阅读理解. #include<iostream> #include<cstdio> #include<cmath> #include< ...
- Mail.Ru Cup 2018 Round 2C(__gcd)
#include<bits/stdc++.h>using namespace std;long long mx(long long l1,long long r1,long long l2 ...
随机推荐
- Python 爬虫知识点 - 淘宝商品检索结果抓包分析(续一)
通过前一节得出地址可能的构建规律,如下: https://s.taobao.com/search?data-key=s&data-value=44&ajax=true&_ksT ...
- Unity3D自己常用代码
常需要,常查找! 自己记录下! 1. var ray = Camera.main.ScreenPointToRay(Input.mousePosition); //GameObject.CreateP ...
- 打开Linux ftp服务,如:vsftpd: unrecognized service
打开Linux ftp服务,如:vsftpd: unrecognized service [root@BZXXDBS02 ~]# service vsftpd start vsftpd: unre ...
- PyQt4 菜单栏 + 工具栏 + 状态栏 + 中心部件 生成一个文本编辑部件示例
我们将创建一个菜单栏.一个工具栏.一个状态栏和一个中心部件. #!/usr/bin/python # -*- coding:utf-8 -*- import sys from PyQt4 import ...
- cocos2dx游戏--欢欢英雄传说--为敌人添加移动和攻击动作
这里主要为敌人添加了一个移动动作和攻击动作.移动动作是很简略的我动他也动的方式.攻击动作是很简单的我打他也打的方式.效果:代码: #ifndef __Progress__ #define __Prog ...
- 【linux】Crontab 定时任务 使用实例
1 使用putty 登录linux 服务器 2 输入以下命令.查看已有的定时任务 crontab -l 3 输入 以下命令,进入定时任务文件 crontab -e 4 键盘 选择 i 键 进行输 ...
- AngularJS』一点小小的理解
『AngularJS』一点小小的理解 AngularJS 是一个前端的以Javascript为主的MVC框架.与AngularJS相类似的还有EmberJS. 随着时代在进步,各种各样的开发理念与 ...
- Unity3D笔记九 发送广播与消息、利用脚本控制游戏
一.发送广播与消息 游戏对象之间发送的广播与消息分为三种:第一种向子对象发送,将发送至该对象的同辈对象或者子孙对象中:第二种为给自己发送,发送至自己本身对象:第三种为向父对象发送,发送至该对象的同辈或 ...
- mysql如何用sql增加字段和注释?
alter table warn_user_binding add is_valid varchar(10) default 'true' COMMENT '删除标识:true 有效:false 删除 ...
- javaWeb中的文件上传下载
在Web应用系统开发中,文件上传和下载功能是非常常用的功能,今天来讲一下JavaWeb中的文件上传和下载功能的实现. 对于文件上传,浏览器在上传的过程中是将文件以流的形式提交到服务器端的,如果直接使用 ...