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 ...
随机推荐
- dubbo小教程
dubbo小教程 先给出阿里巴巴dubbo的主页:http://code.alibabatech.com/wiki/display/dubbo/Home-zh 自己的demo下载地址:http://d ...
- 路飞学城—Python爬虫实战密训班 第三章
路飞学城—Python爬虫实战密训班 第三章 一.scrapy-redis插件实现简单分布式爬虫 scrapy-redis插件用于将scrapy和redis结合实现简单分布式爬虫: - 定义调度器 - ...
- POJ - 2718 Smallest Difference(全排列)
题意:将n个数字分成两组,两组分别组成一个数字,问两个数字的最小差值.要求,当组内数字个数多于1个时,组成的数字不允许有前导0.(2<=n<=10,每个数字范围是0~9) 分析: 1.枚举 ...
- Thread--CountDownLatch & CyclicBarrier
参考:http://www.importnew.com/21889.html CountDownLatch countDown() 方法执行完只是计数器减一, 并不会阻塞当前运行线程的的后续代码执行. ...
- mysql5.6免安装使用
一.去MYSQL官网下载MYSQL免安装版,由于我的系统是64位的,所以就下载了64位的Mysql版本 http://cdn.mysql.com//Downloads/MySQL-5.6/mysql- ...
- .NET技术-5.0. NETCORE设置返回数据字段的大小写
.NET技术-5.0. NETCORE设置返回数据字段的大小写 问题来源于我写了一个接口,接口的返回类型是JsonResult,但是对接之后反应返回结果的首字母全小写了, 后来查了写资料返现.net ...
- 201709-1 打酱油 Java
思路: 先看能不能买5瓶,因为送的最多,然后看能不能买3瓶,最后一瓶一瓶地买 import java.util.Scanner; public class Main { public static v ...
- android studio使用JDBC访问mysql数据库(Kotlin方法)
工具:mysql-connector-java-5.1.48.jar,mysql version 5.6.19,android studio内置模拟器 1.connection import java ...
- Cracking Digital VLSI Verification Interview 第四章
目录 Hardware Description Languages Verilog SystemVerilog 对Cracking Digital VLSI Verification Intervie ...
- uwsgi Import Error: No module named 'encodings'
https://serverfault.com/questions/558427/uwsgi-import-error-no-module-named-encodings I don't know i ...