atcoder CODE FESTIVAL 2017 qual A 手速(雾)赛

本文介绍了atcoder CODE FESTIVAL 2017资格赛的A、C、E、F四道题目,涉及贪心、构造、动态规划和分治等算法。A题通过分析矩阵的对称性得出解决方案;C题利用正方形染色策略构造满足条件的方案;E题通过分情况讨论解决多人行走染色问题;F题通过逆向思考和贪心策略求解最少操作步数。
摘要由CSDN通过智能技术生成

       这个比赛看起来好像挺重要的,,(结果来了一众大佬谁都打不过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个的颜色两两不同,可以发现满足条件。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值