AtCoder Grand Contest 002题解
\(A\)
咕咕
int main(){
cin>>a>>b;
if(b<0)puts(((b-a+1)&1)?"Negative":"Positive");
else if(a>0)puts("Positive");
else puts("Zero");
return 0;
}
\(B\)
模拟一下就行了
const int N=1e5+5;
int sz[N],ok[N],n,m,res;
int main(){
// freopen("testdata.in","r",stdin);
scanf("%d%d",&n,&m);
fp(i,1,n)sz[i]=1;ok[1]=1;
for(R int x,y,i=1;i<=m;++i){
scanf("%d%d",&x,&y);
ok[y]|=ok[x],++sz[y],--sz[x];
if(!sz[x])ok[x]=0;
}
fp(i,1,n)res+=ok[i];
printf("%d\n",res);
return 0;
}
\(C\)
考虑反过来,每一次连接两段绳子,且连接之后长度要大于等于\(L\),那么第一次合并最长的两端,剩下的用这一段绳子去合并其他的就好了
//quming
#include<bits/stdc++.h>
#define R register
#define fp(i,a,b) for(R int i=(a),I=(b)+1;i<I;++i)
#define fd(i,a,b) for(R int i=(a),I=(b)-1;i>I;--i)
#define go(u) for(int i=head[u],v=e[i].v;i;i=e[i].nx,v=e[i].v)
template<class T>inline bool cmin(T&a,const T&b){return a>b?a=b,1:0;}
template<class T>inline bool cmax(T&a,const T&b){return a<b?a=b,1:0;}
using namespace std;
typedef long long ll;
const int N=1e5+5;
int a[N],n,L;
int main(){
// freopen("testdata.in","r",stdin);
scanf("%d%d",&n,&L);
fp(i,1,n)scanf("%d",&a[i]);
R int pos=0;
fp(i,1,n-1)if(a[i]+a[i+1]>=L){pos=i;break;}
if(!pos)return puts("Impossible"),0;
puts("Possible");
fp(i,1,pos-1)printf("%d\n",i);
fd(i,n-1,pos+1)printf("%d\n",i);
printf("%d\n",pos);
return 0;
}
\(D\)
以边的序号为边权建出\(kruskal\)重构树,然后二分最大的序号,判断是否合法就行了
//quming
#include<bits/stdc++.h>
#define R register
#define fp(i,a,b) for(R int i=(a),I=(b)+1;i<I;++i)
#define fd(i,a,b) for(R int i=(a),I=(b)-1;i>I;--i)
#define go(u) for(int i=head[u],v=e[i].v;i;i=e[i].nx,v=e[i].v)
template<class T>inline bool cmin(T&a,const T&b){return a>b?a=b,1:0;}
template<class T>inline bool cmax(T&a,const T&b){return a<b?a=b,1:0;}
using namespace std;
const int N=5e5+5;
struct eg{int v,nx;}e[N];int head[N],tot;
inline void add(R int u,R int v){e[++tot]={v,head[u]},head[u]=tot;}
int fa[N][25],sz[N],dep[N],ga[N],val[N],Log[N];
int n,m,q,nd,l,r,mid,ans;
inline int find(R int x){return ga[x]==x?x:ga[x]=find(ga[x]);}
void dfs(int u){
sz[u]=(u<=n);
for(R int i=1;dep[u]>>i;++i)fa[u][i]=fa[fa[u][i-1]][i-1];
go(u)fa[v][0]=u,dep[v]=dep[u]+1,dfs(v),sz[u]+=sz[v];
}
inline int jump(R int u){
fd(i,Log[dep[u]],0)if(fa[u][i]&&val[fa[u][i]]<=mid)u=fa[u][i];
return u;
}
bool ck(R int u,R int v,R int p){
u=jump(u),v=jump(v);
return (u==v?sz[u]:sz[u]+sz[v])>=p;
}
int main(){
// freopen("testdata.in","r",stdin);
scanf("%d%d",&n,&m);nd=n;
fp(i,1,n)ga[i]=i;
for(R int i=1,u,v,x,y;i<=m;++i){
scanf("%d%d",&u,&v);
u=find(u),v=find(v);
if(u!=v)++nd,ga[u]=ga[v]=ga[nd]=nd,add(nd,u),add(nd,v),val[nd]=i;
}
Log[0]=-1;fp(i,2,nd)Log[i]=Log[i>>1]+1;
dfs(nd);
scanf("%d",&q);
for(R int u,v,p;q;--q){
scanf("%d%d%d",&u,&v,&p);
l=1,r=m,ans=m;
while(l<=r){
mid=(l+r)>>1;
ck(u,v,p)?(ans=mid,r=mid-1):l=mid+1;
}
printf("%d\n",ans);
}
return 0;
}
\(E\)
如果我们把所有的\(a_i\)降序排序,那么我们可以画出一个网格图,其中第\(i\)列有\(a_i\)个格子,初始在\(1,1\),第一个操作对应往右走,第二个操作对应往下走,那么走出边界的输
打表发现\((x,y)\)的答案和\((x+1,y+1)\)的答案相同,那么我们可以暴力找出最大的\((x,x)\),然后计算这个格子的答案就行了
//quming
#include<bits/stdc++.h>
#define R register
#define fp(i,a,b) for(R int i=(a),I=(b)+1;i<I;++i)
#define fd(i,a,b) for(R int i=(a),I=(b)-1;i>I;--i)
#define go(u) for(int i=head[u],v=e[i].v;i;i=e[i].nx,v=e[i].v)
template<class T>inline bool cmin(T&a,const T&b){return a>b?a=b,1:0;}
template<class T>inline bool cmax(T&a,const T&b){return a<b?a=b,1:0;}
using namespace std;
const int N=1e5+5;
int a[N],n,m,las,pos,t;
int main(){
scanf("%d",&n);
fp(i,1,n)scanf("%d",&a[i]);
sort(a+1,a+1+n),reverse(a+1,a+1+n);
fp(i,1,n)if(a[i]>=i)pos=i;else break;
a[n+1]=0,t=1;fp(i,pos+1,n)if(a[i]==pos)t^=1;else break;
puts(!(((a[pos]-pos+1)&1)&t)?"First":"Second");
return 0;
}
\(F\)
对于每种颜色,我们把它变成一个无色的球和\(k-1\)个有颜色的球,那么发现,我们需要满足位置关系的只有这些无色的球和每个颜色第一次出现的位置(记为特殊位置),并且满足每一个前缀中无色球的个数都大于等于特殊位置的个数
那么我们倒着放球,设\(f_{i,j}\)表示放了后\(i\)个位置,且这\(i\)个位置中有\(j\)个特殊位置的方案数,那么后面放的总球数就是\(i+j\times (k-1)\),转移的时候用组合数乘一下就可以了
//quming
#include<bits/stdc++.h>
#define R register
#define fp(i,a,b) for(R int i=(a),I=(b)+1;i<I;++i)
#define fd(i,a,b) for(R int i=(a),I=(b)-1;i>I;--i)
#define go(u) for(int i=head[u],v=e[i].v;i;i=e[i].nx,v=e[i].v)
template<class T>inline bool cmin(T&a,const T&b){return a>b?a=b,1:0;}
template<class T>inline bool cmax(T&a,const T&b){return a<b?a=b,1:0;}
using namespace std;
const int P=1e9+7;
inline void upd(R int &x,R int y){(x+=y)>=P?x-=P:0;}
inline int add(R int x,R int y){return x+y>=P?x+y-P:x+y;}
inline int dec(R int x,R int y){return x-y<0?x-y+P:x-y;}
inline int mul(R int x,R int y){return 1ll*x*y-1ll*x*y/P*P;}
int ksm(R int x,R int y){
R int res=1;
for(;y;y>>=1,x=mul(x,x))(y&1)?res=mul(res,x):0;
return res;
}
const int N=5005,M=5e6+5;
int f[N][N],fac[M],ifac[M],n,k;
inline int C(R int n,R int m){return m>n?0:1ll*fac[n]*ifac[m]%P*ifac[n-m]%P;}
inline void init(R int n=5e6){
fac[0]=ifac[0]=1;fp(i,1,n)fac[i]=mul(fac[i-1],i);
ifac[n]=ksm(fac[n],P-2);fd(i,n-1,1)ifac[i]=mul(ifac[i+1],i+1);
}
int main(){
scanf("%d%d",&n,&k),--k;
if(!k)return puts("1"),0;
init();
f[0][0]=1;
fp(i,0,(n<<1)-1)fp(j,0,min(i,n))if(f[i][j]){
if(j+1<=n)upd(f[i+1][j+1],mul(n-j,mul(f[i][j],C(i+j*(k-1)+k-1,k-1))));
if((i+1-j)<=j)upd(f[i+1][j],f[i][j]);
}
printf("%d\n",f[n<<1][n]);
return 0;
}
AtCoder Grand Contest 002题解的更多相关文章
- AtCoder Grand Contest 002
AtCoder Grand Contest 002 A - Range Product 翻译 告诉你\(a,b\),求\(\prod_{i=a}^b i\)是正数还是负数还是零. 题解 什么鬼玩意. ...
- AtCoder Grand Contest 002 F:Leftmost Ball
题目传送门:https://agc002.contest.atcoder.jp/tasks/agc002_f 题目翻译 你有\(n*k\)个球,这些球一共有\(n\)种颜色,每种颜色有\(k\)个,然 ...
- AtCoder Grand Contest 017 题解
A - Biscuits 题目: 给出 \(n\) 个物品,每个物品有一个权值. 问有多少种选取方式使得物品权值之和 \(\bmod\space 2\) 为 \(p\). \(n \leq 50\) ...
- Atcoder Grand Contest 054 题解
那天晚上由于毕业晚会与同学吃饭喝酒没打 AGC,第二天稍微补了下题,目前补到了 E,显然 AGC 的 F 对于我来说都是不可做题就没补了(bushi A 简单题,不难发现如果我们通过三次及以上的操作将 ...
- AtCoder Grand Contest 030题解
第一次套刷AtCoder 体验良好 传送门 Poisonous Cookies cout<<b+min(c,a+b+); Tree Burning 难度跨度有点大啊 可以证明当第一次转向之 ...
- AtCoder Grand Contest 002 (AGC002) F - Leftmost Ball 动态规划 排列组合
原文链接https://www.cnblogs.com/zhouzhendong/p/AGC002F.html 题目传送门 - AGC002F 题意 给定 $n,k$ ,表示有 $n\times k$ ...
- AtCoder Grand Contest 031题解
题面 传送门 题解 比赛的之后做完\(AB\)就开始发呆了--简直菜的一笔啊-- \(A - Colorful\ Subsequence\) 如果第\(i\)个字母选,那么它前面任意一个别的字母的选择 ...
- [Atcoder Grand Contest 002] Tutorial
Link: AGC002 传送门 A: …… #include <bits/stdc++.h> using namespace std; int a,b; int main() { sca ...
- AtCoder Grand Contest 039 题解
传送门 \(A\) 首先只有一串的情况下,遇到相同的肯定是改后面那一个最优,然后两串的话可能要分奇偶讨论一下 //quming #include<bits/stdc++.h> #defin ...
随机推荐
- idea代码提示快捷键设置
代码提示快捷键设置: keymap--Main Menu--Code--Completion--Basic
- Luogu5307 [COCI2019] Mobitel 【数论分块】【递推】
题目分析: 对于向上取整我们总有,$\lceil \frac{\lceil \frac{n}{a} \rceil}{b} \rceil = \lceil \frac{n}{a*b} \rceil$这个 ...
- linux 设置用户组共享文件
1.首先建立一个名为workgroup的用户组,然后向用户组里面添加两名用户 tom 和liming,并为其设置密码 sudo groupadd workgroup [sudo] lcy 的密码: s ...
- VS.NET(C#)--2.6_ASP.NET服务器控件层次结构
ASP.NET服务器控件层次结构 语法 <asp:ControlType Id="ControlID" Rubat="Server" Property=& ...
- 3_PHP表达式_5_数据类型转换_类型强制转换
以下为学习孔祥盛主编的<PHP编程基础与实例教程>(第二版)所做的笔记. PHP类型转换分为类型自动转换和类型强制转换. 3.5.2 类型强制转换 类型强制转换允许编程人员手动将变量的数据 ...
- @app.route源码流程分析
@app.route(), 是调用了flask.app.py文件里面的Flask类的route方法,route方法所做的事情和add_url_rule类似,是用来为一个URL注册一个视图函数,但是我们 ...
- 制作一个简单的部门员工知识分享的python抽取脚本
需求: 基于公司的文化和公司部门间以及员工之间的工作需求状态,或者想要了解某一些技能.专业方面的知识需求.促进并提高员工们的技能认知和技术水平. 详细代码如下: 先说一下存入csv表格的表头字段: 1 ...
- Linux sudo(CVE-2019-14287)漏洞复现过程
简述: 该漏洞编号是CVE-2019-14287. sudo是Linux系统管理指令,允许用户在不需要切换环境的前提下用其他用户的权限运行程序或命令,通常是以root身份运行命令,以减少root用户的 ...
- 在Linux中安装ASPNET.Core3.0运行时
# 以下示例适用于x64位runtime v3.0.0 mkdir /runtimes cd /runtimes wget https://download.visualstudio.microsof ...
- 【OF框架】在Visual Studio中发布Docker镜像,推送镜像到Azure容器注册表
准备 拥有Azure账号,已经创建 Azure容器注册表,获得注册表地址.账号.密码 本地已经在Visual Studio登录Azure账号. 本地已经拥有Docker环境 注意:首次发布Docker ...