求助,玄关!!!
查看原帖
求助,玄关!!!
1382038
linruicong楼主2025/1/31 18:20

题目
记录

#include<bits/stdc++.h>
using namespace std;
int t,n,m,a[105][105],vis[105],viss[105],sum1,sum0,sum,mak1,mak0,tmp1[105],tmp0[105];
void fun1() 
{
	if(mak1==0)
	{
		for(int i=1;i<=tmp1[0];i++) vis[tmp1[i]]=1;
	}
	if(mak0==0)
	{
		for(int i=1;i<=tmp0[0];i++) vis[tmp0[i]]=1;
	}
}
void fun()
{
	memset(a,0,sizeof a);
	memset(vis,0,sizeof vis);
	n=0;
	m=0;
	sum1=0;
	sum0=0;
	mak1=0;
	mak0=0;
	scanf("%d%d",&n,&m);
	for(int i=1;i<=n;i++) viss[i]=1;
	for(int i=1;i<=m;i++)
	{
		for(int j=1;j<=n;j++) scanf("%1d",&a[i][j]);
		scanf("%d",&a[i][0]);
	}
	for(int i=1;i<=n;i++)
	{
		sum1=0;sum0=0;mak1=0;mak0=0;
		memset(tmp1,0,sizeof tmp1);
		memset(tmp0,0,sizeof tmp0);
		for(int j=1;j<=m;j++)
		{
			if(vis[j]==1) continue;
			if(a[j][i]==1&&sum1==0) {sum1=j;continue;}
			if(a[j][i]==1&&a[sum1][0]!=a[j][0]) mak1=1;
			if(a[j][i]==1&&a[sum1][0]==a[j][0])
			{
				sum1=j;
				tmp1[++tmp1[0]]=j;
			}
			if(a[j][i]==0&&sum0==0) sum0=j;
			if(a[j][i]==0&&a[sum0][0]!=a[j][0]) mak0=1;
			if(a[j][i]==0&&a[sum0][0]==a[j][0])
			{
				sum0=j;
				tmp0[++tmp0[0]]=j;
			}
		}
		fun1();
	}
	sum=0;
	for(int i=1;i<=m;i++)
	{
		if(vis[i]==1) continue;
		if(sum==0) sum=a[i][0];
		if(sum!=a[i][0])
		{
			printf("LIE\n");
			return ;
		}
		if(sum==a[i][0]) sum=a[i][0];
	}
	printf("OK\n");
}
int main()
{
	freopen("c.in","r",stdin);
	freopen("c.out","w",stdout);
	scanf("%d",&t);
	while(t--) fun();
	return 0;
}
2025/1/31 18:20
加载中...