⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 2722437_wa.c

📁 北大大牛代码 1240道题的原代码 超级权威
💻 C
字号:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int m, n, k;
int chess[27][27];

int valid(int a,int b)
{
	if(a<0||b<0||a>=m||b>=n)
		return 0;
	return 1;
}

int check()
{
	int i, j, k, num;
	int a, b;

	num = 0;
	for (i = 0; i < m; i++)
	{
		for (j = 0; j < n; j++)
		{
			if (!chess[i][j])
			{
				for (k = 0; k < n; k++)
				{
					if (chess[i][k])
						goto loop;
				}
				for (k = 0; k < m; k++)
				{
					if (chess[k][j])
						goto loop;
				}
				a = i;b = j;
				while(valid(a,b))
				{
					if(chess[a][b])
						goto loop;
					a++,b++;
				}
				a = i;b = j;
				while(valid(a,b))
				{
					if(chess[a][b])
						goto loop;
					a--,b--;
				}
				num++;
			}
loop:
			;
		}
	}
	return num;
}

int main()
{
	int i, j, t;
	int a, b, max;
	char tmp[4];

	max = -1;
	scanf("%d%d%d",&m,&n,&k);
	memset(chess,0,sizeof(chess));
	for (i = 0; i < k; i++)
	{
		scanf("%s",tmp);
		chess[tmp[0]-'a'][atoi(&tmp[1])-1] = 1;
	}
	for (i = 0; i < m; i++)
	{
		for (j = 0; j < n; j++)
		{
			if (!chess[i][j])
			{
				chess[i][j] = 1;
				t = check();
				chess[i][j] = 0;
				if (t > max)
				{
					max = t;
					a = i;
					b = j;
				}
			}
		}
	}
	printf("%c%d\n%d\n",a+'a',b+1,max);
	return 0;
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -