这个比赛看起来好像挺重要的,,(结果来了一众大佬谁都打不过qaq)
A,B题不知道是干什么的
C题(其实也是不知道在干什么)就是给一个字母矩阵,重排列后问是否能使它水平轴对称+竖直轴对称。
可以发现一个矩阵最多由三部分组成:1.中心点,需要1个字母;2.中轴线,需要2个相同字母为1对填上去;3.其余部分,需要4个相同字母为1组填上去。显然能填3就能填2,能填2就能填1,因此考虑从3->2->1贪心放即可。
AC代码如下:
#include<bits/stdc++.h>
using namespace std;
int m,n,num[26]; char s[100009];
int main(){
scanf("%d%d",&m,&n);
int s1=(m>>1)*(n>>1),s2=(m&1)*(n>>1)+(m>>1)*(n&1),s3=m&n&1;
int i,j;
for (i=1; i<=m; i++){
scanf("%s",s+1);
for (j=1; j<=n; j++) num[s[j]-'a']++;
}
for (i=0; i<26; i++){
while (num[i]>=4 && s1){ num[i]-=4; s1--; }
while (num[i]>=2 && s2){ num[i]-=2; s2--; }
while (num[i] && s3){ num[i]--; s3--; }
if (num[i]) break;
}
puts(i<26?"No":"Yes");
return 0;
}
从D题开始才开始有含金量的题目,,(可能F题也不那么难?),,然后我开场开了D题,看错输出格式爆了2发oj,,,啊难受
题意就是给你m,n,d,要求构造一个染4色的方案,使得曼哈顿距离恰好为d的任何一对点颜色不同。
首先考虑x+y->x,x-y->y,这样就变成了以(x,y)为中心,边心距为d的正方形的轮廓不能喝(x,y)同色。考虑x所在的行,我们可以采用先d个为一段,换一种颜色再d个为一段,再换回原来的颜色d个一段的方式染。这样可以推广到2维,考虑以一个d*d的正方形为一个单位,然后每4个的颜色两两不同,可以发现满足条件。