AtCoder Grand Contest 033
为什么ABC那么多?建议Atcoder多出些ARC/AGC,好不容易才轮到AGC……
A
签到。就是以黑点为源点做多元最短路,由于边长是1直接bfs就好了,求最长路径。
#include<bits/stdc++.h>
using namespace std;
const int N=,dx[]={,,,-},dy[]={,-,,};
int n,m,ans,qs,qe,d[N][N],qx[N*N],qy[N*N];
char mp[N][N];
int main()
{
cin>>n>>m;
for(int i=;i<=n;i++)scanf("%s",mp[i]+);
for(int i=;i<=n;i++)
for(int j=;j<=m;j++)
if(mp[i][j]=='.')d[i][j]=1e9;
else d[i][j]=,qx[qe]=i,qy[qe++]=j;
while(qs<qe)
{
int x=qx[qs],y=qy[qs++];
for(int i=;i<;i++)
{
int u=x+dx[i],v=y+dy[i];
if(u<||u>n||v<||v>m||d[u][v]<=d[x][y]+)continue;
d[u][v]=d[x][y]+,ans=max(ans,d[u][v]);
qx[qe]=u,qy[qe++]=v;
}
}
cout<<ans<<endl;
}
B
实际上上下和左右可以分开算。假设只有U和D,那么所有U/D操作结束后,若保留在棋盘,则在区间[L,R],于是根据是先手还是后手的操作,更改区间,若区间在操作途中为空或最终区间不包含棋子所在行/列,则先手获胜,反之后手获胜
#include<bits/stdc++.h>
using namespace std;
const int N=2e5+;
int n,m,p,sr,sc;
char s[N],t[N];
bool walk1()
{
int L=,R=n;
for(int i=p;i;i--)
{
if(t[i]=='U')R=min(n,R+);else if(t[i]=='D')L=max(,L-);
if(s[i]=='U')L++;else if(s[i]=='D')R--;
if(L>R)return ;
}
return (sr<L||sr>R);
}
bool walk2()
{
int L=,R=m;
for(int i=p;i;i--)
{
if(t[i]=='L')R=min(m,R+);else if(t[i]=='R')L=max(,L-);
if(s[i]=='L')L++;else if(s[i]=='R')R--;
if(L>R)return ;
}
return (sc<L||sc>R);
}
int main()
{
scanf("%d%d%d%d%d",&n,&m,&p,&sr,&sc);
scanf("%s",s+);
scanf("%s",t+);
if(walk1()||walk2())puts("NO");
else puts("YES");
}
C
发现每次操作对树的改变只有2种:1、删去所有叶节点(n=2时不可使用)。2、保留其中一个叶节点,删去其他点(n=1时不可使用)。开始瞎蒙个SG函数的错误结论上去,白掉5min。然后发现树等价于长为直径的链上游戏,于是DP链长度为i时先手是否必胜即可。
#include<bits/stdc++.h>
using namespace std;
const int N=2e5+;
int n,f[N],dep[N];
vector<int>G[N];
void dfs(int u,int fa)
{
for(int i=;i<G[u].size();i++)
if(G[u][i]!=fa)dep[G[u][i]]=dep[u]+,dfs(G[u][i],u);
}
int main()
{
scanf("%d",&n);
f[]=,f[]=;
for(int i=;i<=n;i++)if(f[i-]&&f[i-])f[i]=;else f[i]=;
for(int i=,x,y;i<n;i++)scanf("%d%d",&x,&y),G[x].push_back(y),G[y].push_back(x);
dfs(,);
int t=;
for(int i=;i<=n;i++)if(dep[i]>dep[t])t=i;
for(int i=;i<=n;i++)dep[i]=;
dfs(t,);
t=;
for(int i=;i<=n;i++)t=max(t,dep[i]);
if(f[t])puts("First");else puts("Second");
}
D
很容易发现答案是O(logn)级别的,不妨考虑按照答案分步DP,设f[ans][i][j][k]表示答案<=ans,上下边界分别为i,j,左边界为k,右边界最靠右能达到多少。然后考虑转移,竖切可以直接转移,横切由于枚举横切点发现上下区间的DP值一个是先增后减,另一个是先减后增,然后可以二分转移。假设n,m同级,复杂度O(n3log2n)
#include<bits/stdc++.h>
using namespace std;
const int N=;
int n,m,f[][N][N][N];
char s[N][N];
int main()
{
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++)scanf("%s",s[i]+);
for(int i=n;i;i--)
for(int j=i;j<=n;j++)
for(int k=m;k;k--)
if(i==j)
{
if(k==m)f[][i][j][k]=m+;
else f[][i][j][k]=s[i][k]==s[i][k+]?f[][i][j][k+]:k+;
}
else f[][i][j][k]=s[i][k]==s[i+][k]?min(f[][i][i][k],f[][i+][j][k]):k;
for(int ans=,t=;;ans++,t^=)
{
if(f[t][][n][]==m+){printf("%d\n",ans);return ;}
for(int i=n;i;i--)
for(int j=i;j<=n;j++)
for(int k=m;k;k--)
{
f[t^][i][j][k]=f[t][i][j][k]==m+?m+:f[t][i][j][f[t][i][j][k]];
if(i<j)
{
int l=i,r=j-,mid;
while(l<=r)
{
mid=l+r>>;
if(f[t][i][mid][k]<=f[t][mid+][j][k])
f[t^][i][j][k]=max(f[t^][i][j][k],f[t][i][mid][k]),r=mid-;
else f[t^][i][j][k]=max(f[t^][i][j][k],f[t][mid+][j][k]),l=mid+;
}
}
}
}
}
EF
咕
result:rank217 rating+=47 now_rating=1925
AtCoder Grand Contest 033的更多相关文章
- Atcoder Grand Contest 033 D - Complexity(dp)
Atcoder 题面传送门 & 洛谷题面传送门 首先 \(n^5\) 的暴力非常容易想,设 \(dp_{a,b,c,d}\) 表示以 \((a,b)\) 为左上角,\((c,d)\) 为右下角 ...
- AtCoder Grand Contest 033 题解
传送门 我比赛的时候怕不是在睡觉啊-- \(A\ Darker\ and\ Darker\) 我是不是想得太复杂了--根本没必要像我这样做吧-- 首先问题可以转化成令\(p_{i,j}\)表示到\(( ...
- AtCoder Grand Contest 012
AtCoder Grand Contest 012 A - AtCoder Group Contest 翻译 有\(3n\)个人,每一个人有一个强大值(看我的假翻译),每三个人可以分成一组,一组的强大 ...
- AtCoder Grand Contest 011
AtCoder Grand Contest 011 upd:这篇咕了好久,前面几题是三周以前写的... AtCoder Grand Contest 011 A - Airport Bus 翻译 有\( ...
- AtCoder Grand Contest 031 简要题解
AtCoder Grand Contest 031 Atcoder A - Colorful Subsequence description 求\(s\)中本质不同子序列的个数模\(10^9+7\). ...
- AtCoder Grand Contest 010
AtCoder Grand Contest 010 A - Addition 翻译 黑板上写了\(n\)个正整数,每次会擦去两个奇偶性相同的数,然后把他们的和写会到黑板上,问最终能否只剩下一个数. 题 ...
- AtCoder Grand Contest 009
AtCoder Grand Contest 009 A - Multiple Array 翻译 见洛谷 题解 从后往前考虑. #include<iostream> #include< ...
- AtCoder Grand Contest 008
AtCoder Grand Contest 008 A - Simple Calculator 翻译 有一个计算器,上面有一个显示按钮和两个其他的按钮.初始时,计算器上显示的数字是\(x\),现在想把 ...
- AtCoder Grand Contest 007
AtCoder Grand Contest 007 A - Shik and Stone 翻译 见洛谷 题解 傻逼玩意 #include<cstdio> int n,m,tot;char ...
随机推荐
- UVALive 5913 字典树
先输入n个字符串的字典,每个字符串的前缀+后缀可以组成新的合法字符串,但肯定是有重复的,问从给定的字符串,生成的所有可能的字符串为多少个 把前缀和后缀压入字典树,达到前缀和后缀的去重,首先的总和即为前 ...
- 学术Essay写作中Introduction的正确打开方式
其实在学术essay写作过程中,很多留学生经常不知道如何写introduction,所以有些开头的模板句就出现了,比如,With the development of society/With the ...
- [题解] Luogu P2000 拯救世界
生成函数板子题...... 要写高精,还要NTT优化......异常dl 这个并不难想啊...... 一次召唤会涉及到\(10\)个因素,全部写出来,然后乘起来就得到了答案的生成函数,输出\(n\)次 ...
- python 变量搜寻顺序法则LEGB之E注意事项
众所周知,在python中,变量不需要事先声明,赋值后,即可调用使用.而调用的法则遵从LEGB法则,其中L为local,E为enclosing,G为Global,B为built-in,即变量首先在局部 ...
- 吴裕雄--天生自然 JAVASCRIPT开发学习
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- PTA 天梯赛 L1
L1-002 打印沙漏 细节:就是在 (i>j&&i+j<r+1) 这个区间里才有空格,然后就是 for 循环 for(r=1; ;r+=2) 条件不满足之后还会再 ...
- 恒生UFX交易接口基本介绍
https://zhidao.baidu.com/question/203296047903136445.html 1.恒生UFT和UFX有什么区别? UFT是一个极速交易系统,UFX是一个统一接入系 ...
- scala通过尾递归解析提取字段信息
一.背景 获取数据中以“|”作为字段间的分隔符,但个别字段中数据也是以“|”作为分隔符.因此,在字段提取时需要保护数据完整性. 二.实现 1.数据以“|”分隔,可以采用递归方式迭代解析.通过尾递归方式 ...
- 使用axis调用webservice接口
以前使用webservice服务都很简单,就是根据提供的wsdl接口地址,通过eclipse或者idea自动生成webservice client包,然后直接调用就可以了.这次业务提供的wsdl是需要 ...
- 吴裕雄--天生自然 JAVASCRIPT开发学习:DOM EventListener
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...