【JZOJ 3229】 回文子序列

题目大意:

我们会给定一个 \(N\times M\) 的矩阵,你需要从这个矩阵中找出一个 \(P\times P\) 的子矩阵,使得这个子矩阵的每一列和每一行都是回文序列。

正文:

这题数据水,暴力可过:三个方确定矩阵,两个方判断是否回文。

代码:

for (int len = min(n, m); len >= 1; len--)
{
	for (int i = 1; i <= n - len + 1; i++)
		for (int j = 1; j <= m - len + 1; j++)
		{
			bool flag = 1;
			for (int ii = 0; ii < len; ii++)
			{	
				for (int jj = 1; jj <= (len / 2); jj++)
					if(a[i + ii][j + jj - 1] != a[i + ii][j + len - jj] ||
					   a[i + jj - 1][j + ii] != a[i + len - jj][j + ii])
					{
						flag = 0;
						break;
					}
				if(!flag) break;
			}
			if(flag)
			{
				printf("%d", len);
				return 0;
			}
		}
}
posted @ 2020-08-09 19:29  Jayun  阅读(99)  评论(0编辑  收藏  举报