传送门

\(A\)

咕咕

int x,y;
int c[4]={0,300000,200000,100000};
int res;
int main(){
cin>>x>>y;
if(x<=3)res+=c[x];
if(y<=3)res+=c[y];
if(x==1&&y==1)res+=4e5;
cout<<res<<endl;
return 0;
}

\(B\)

咕咕

const int N=2e5+5;
typedef long long ll;
int a[N],n;ll sum[N],suf[N],res;
int main(){
scanf("%d",&n);
fp(i,1,n)scanf("%d",&a[i]),sum[i]=suf[i]=a[i];
fp(i,1,n)sum[i]+=sum[i-1];fd(i,n,1)suf[i]+=suf[i+1];
res=1e18;
fp(i,1,n-1)cmin(res,abs(sum[i]-suf[i+1]));
printf("%lld\n",res);
return 0;
}

\(C\)

一道思博题想了这么久看来脑子已经没用了

如果每行都有草莓那么每行分别考虑,对于没有草莓的行缩起来就行了

//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 cmax(T&a,const T&b){return a<b?a=b,1:0;}
template<class T>inline bool cmin(T&a,const T&b){return a>b?a=b,1:0;}
using namespace std;
const int N=305;
char mp[N][N];int col[N][N],n,m,cnt,K;
int main(){
scanf("%d%d%d",&n,&m,&K);
fp(i,1,n)scanf("%s",mp[i]+1);
fp(i,1,n)fp(j,1,m)if(mp[i][j]=='#'){
col[i][j]=++cnt;
for(R int k=j-1;k&&!col[i][k]&&mp[i][k]!='#';--k)col[i][k]=cnt;
for(R int k=j+1;k<=m&&!col[i][k]&&mp[i][k]!='#';++k)col[i][k]=cnt;
}
fp(i,1,n)fp(j,1,m)if(col[i][j]){
for(R int k=i-1;k&&!col[k][j];--k)col[k][j]=col[i][j];
for(R int k=i+1;k<=n&&!col[k][j];++k)col[k][j]=col[i][j];
}
fp(i,1,n)fp(j,1,m)printf("%d%c",col[i][j]," \n"[j==m]);
return 0;
}

\(D\)

傻了,什么神仙题

我们发现一次操作要么使总位数减1总和不变,要么使总和减9总位数不变,而最终的情况一定是位数为1总和小于等于9,记总位数为d,总和为s,答案就是\(d-1+(s-1)/9\)

const int N=2e5+5;
typedef long long ll;
int d[N],n;ll c[N],res,sum;
int main(){
scanf("%d",&n);
fp(i,1,n)scanf("%d%lld",&d[i],&c[i]),sum+=c[i],res+=d[i]*c[i];
printf("%lld\n",(res-1)/9+sum-1);
return 0;
}

\(E\)

我们记\(d(i)=query(i,i+n-1)\),如果存在某个\(d(i)\neq d(i+1)\),那么显然\(i\)和\(i+n\)的颜色就可以知道了,同时\((i+1,i+n-1)\)这个区间中一定是红蓝次数各一半,我们可以用它去check出其他所有颜色

所以问题是怎么找到这个分界点,它实际上是可以二分的,我们初始时记\(l=1,r=n+1\),那么\(d(l)\neq d(r)\)显然成立,我们每一次判断\(mid\),如果\(d(mid)=d(l)\)则令\(l=mid\),否则令\(r=mid\),这样一直二分到\(r-l=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 cmax(T&a,const T&b){return a<b?a=b,1:0;}
template<class T>inline bool cmin(T&a,const T&b){return a>b?a=b,1:0;}
using namespace std;
const int N=505;
char s[5];int a[N],col[N],bs[N],cnt[2],n,las,now,ql,qr,l,r,mid,ans;
inline int ask(R int l,R int r){
putchar('?'),putchar(' ');
fp(i,l,r)printf("%d ",i);
putchar('\n'),fflush(stdout);
scanf("%s",s+1);return s[1]=='R';
}
inline int ask(R int l,R int r,R int x,R int d){
putchar('?'),putchar(' ');
fp(i,l,r)if(i!=x)printf("%d ",i);
if(d)printf("%d ",x);
putchar('\n'),fflush(stdout);
scanf("%s",s+1);
if(s[1]=='-')while(true);
return s[1]=='R';
}
int main(){
// freopen("testdata.in","r",stdin);
scanf("%d",&n);
fp(i,1,n<<1)col[i]=-1;
l=1,r=n+1,ans=0,bs[1]=ask(1,n),bs[n+1]=bs[1]^1;
while(r-l>1){
mid=(l+r)>>1,bs[mid]=ask(mid,mid+n-1);
bs[mid]==bs[l]?l=mid:r=mid;
}
col[l]=bs[l],col[r+n-1]=bs[r];
ql=r,qr=r+n-2;
fp(i,ql,qr)col[i]=ask(ql-1,qr+1,i,0)^1;
fp(i,1,ql-2)col[i]=ask(ql,qr,i,1);
fp(i,qr+2,n<<1)col[i]=ask(ql,qr,i,1);
putchar('!'),putchar(' ');
fp(i,1,n<<1)putchar(col[i]?'R':'B');
putchar('\n'),fflush(stdout);
return 0;
}

\(F\)

首先,可以发现如果一个状态转移一次之后每个格子都有一个机器人,那么这个状态肯定是合法的

如果一直往下走,那么循环节就是\(g={n\over \gcd(n,T)}\),往右走循环节是\(h={m\over \gcd(m,T)}\),那么这个\(g\times h\)的子矩形只会受自己内部影响,和外面无关,所以我们可以对于每个这样的子矩形单独考虑

这样我们可以把问题转化为一个\(g\times h\)的子矩形且\(T=1\),我们考虑合法的方案,一种是存在某个格子不走,那么整个矩形全都不走,一种是分别考虑每行,要么不走要么全往右,一种是每列都是全往下,这个直接组合数算一下,全都不走的情况也会在后两种里被算到,要去掉

还有一种情况是既往右又往下,假设我们先固定\((1,1)\)为右,那么\((1,2)\)就不能被\((n,2)\)走到了,所以\((n,2)\)也必然是右,以此类推我们可以确定\({h\times g\over \gcd(h,g)}\)个格子,那么对于所有\(\gcd(h,g)\)个格子每个都有两种方案,直接算一下就好了,记得把全往右和全往下的情况也去掉

//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 cmax(T&a,const T&b){return a<b?a=b,1:0;}
template<class T>inline bool cmin(T&a,const T&b){return a>b?a=b,1:0;}
using namespace std;
typedef long long ll;
const int P=1e9+7;
inline void upd(R int &x,R int y){(x+=y)>=P?x-=P:0;}
inline int inc(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 ll y){
R int res=1;
for(;y;y>>=1,x=mul(x,x))(y&1)?res=mul(res,x):0;
return res;
}
int n,m,T,res,h,g;
int main(){
scanf("%d%d%d",&n,&m,&T);
h=n/__gcd(n,T),g=m/__gcd(m,T);
// printf("%d %d\n",h,g);
res=((0ll+1+ksm(2,h)-1+ksm(2,g)-1+ksm(2,__gcd(h,g))-2)%P+P)%P;
res=ksm(res,1ll*(n/h)*(m/g));
printf("%d\n",res);
return 0;
}

DISCO Presents Discovery Channel Code Contest 2020 Qual题解的更多相关文章

  1. DISCO Presents Discovery Channel Code Contest 2020 Qual Task E. Majority of Balls

    Not able to solve this problem during the contest (virtual participation). The first observation is ...

  2. IOCCC(The International Obfuscated C Code Contest)

    国际 C 语言混乱代码大赛(IOCCC, The International Obfuscated C Code Contest)是一项国际编程赛事,从 1984 年开始,每年举办一次(1997年.1 ...

  3. 【AtCoder】CODE FESTIVAL 2016 qual A

    CODE FESTIVAL 2016 qual A A - CODEFESTIVAL 2016 -- #include <bits/stdc++.h> #define fi first # ...

  4. 【AtCoder】CODE FESTIVAL 2016 qual B

    CODE FESTIVAL 2016 qual B A - Signboard -- #include <bits/stdc++.h> #define fi first #define s ...

  5. 【AtCoder】CODE FESTIVAL 2016 qual C

    CODE FESTIVAL 2016 qual C A - CF -- #include <bits/stdc++.h> #define fi first #define se secon ...

  6. CODE FESTIVAL 2017 qual B B - Problem Set【水题,stl map】

    CODE FESTIVAL 2017 qual B B - Problem Set 确实水题,但当时没想到map,用sort后逐个比较解决的,感觉麻烦些,虽然效率高很多.map确实好写点. 用map: ...

  7. CODE FESTIVAL 2017 qual B C - 3 Steps【二分图】

    CODE FESTIVAL 2017 qual B C - 3 Steps 题意:给定一个n个结点m条边的无向图,若两点间走三步可以到,那么两点间可以直接连一条边,已经有边的不能连,问一共最多能连多少 ...

  8. M-SOLUTIONS Programming Contest 2020 题解

    M-SOLUTIONS Programming Contest 2020 题解 目录 M-SOLUTIONS Programming Contest 2020 题解 A - Kyu in AtCode ...

  9. Comet OJ - Contest #2 简要题解

    Comet OJ - Contest #2 简要题解 cometoj A 模拟,复杂度是对数级的. code B 易知\(p\in[l,r]\),且最终的利润关于\(p\)的表达式为\(\frac{( ...

随机推荐

  1. MySQL数据类型之BLOB与TEXT及其最大存储限制

    https://blog.csdn.net/q3dxdx/article/details/51014357 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.n ...

  2. ASP.NET MVC实现单用户登录

    现在许多网站都要求登录后才能进行进一步的操作,当不允许多用户同时登录一个帐号时,就需要一种机制,当再登录一个相同的帐号时,前面登录的人被挤下线,或者禁止后面的人登录.这里实现的是前一种功能. 网上有许 ...

  3. (原创)C#操作MYSQL数据库

    应用程序对数据库的操作都是只有4个:增,删,改,查. 只有”查”的操作需要使用适配器来存储查询得到的数据.其它3个操作不需要用到适配器. 不同的数据库有共同操作方法:都要建立连接对象,连接对象要有连接 ...

  4. 分布式系统根基:物理时钟和Lamport逻辑时钟

    分布式系统解决了传统单体架构的单点问题和性能容量问题,另一方面也带来了很多的问题,其中一个问题就是多节点的时间同步问题:不同机器上的物理时钟难以同步,导致无法区分在分布式系统中多个节点的事件时序.19 ...

  5. HDFS文件浏览页返回上级目录功能

    1.效果预览 Hadoop自带的效果 修改后,多了一个../按钮,点击可以回到上级目录 2.查找页面和JS文件 我们在浏览器上可以看到访问了explorer.html页面,可以尝试使用find命令查找 ...

  6. Vue学习之过滤器和自定义指令小结(三)

    过滤器: 过滤是一个数据经过了这个过滤之后出来另一样东西,可以是从中取得你想要的,或者给那个数据添加点什么装饰.过滤器就是过滤用的工具.渲染数据用的!!! 我们需要知道的是: 1.Vue中的过滤器不能 ...

  7. Java 之 比较器( Comparator接口与 Comparable 接口)

    一.定制排序:java.util.Comparator 接口 强行对某个对象 collection 进行整体排序 的比较函数.可以将 Comparator 传递给 sort 方法(如 Collecti ...

  8. Java 面向对象—非静态代码块

    一.非静态代码块 1.声明格式 [修饰符] class 类名 { { 非静态代码块 } } 2.非静态代码块中的代码执行时机 (1)在"每次"创建对象的时候执行 (2)比构造方法早 ...

  9. 英语gzibeads天珠gzibeads单词

    天珠英语是gZiBeads,藏语叫(si , 斯)汉语译为“斯”或“瑟”,又称“天降石”.在<藏汉大辞典>里天珠的解释为:“亚玛瑙,猫睛石,一种宝石,俗称九眼珠.入药能治脑溢血”.最早的天 ...

  10. Golang: 解析JSON数据之二

    上次我们介绍了 Go 语言中序列化和反序列化 JSON 数据的两个方法 Marshal() 和 Unmarshal(),并以示例演示了它们的用法. 我们在例子中看到,需要事先声明好对应的结构体,才能跟 ...