题目
记录
#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;
}