QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#102747 | #5254. Differences | csw_ccc# | TL | 0ms | 0kb | C++14 | 1.0kb | 2023-05-03 16:57:22 | 2023-05-03 16:57:25 |
Judging History
answer
#include <iostream>
#include <cstdio>
#include <cmath>
#include <cstring>
#include<string>
#include<cstdlib>
#include<algorithm>
using namespace std;
int n,m,k;
string str[200000+5];
int t[200000+5],s[200000+5];
bool getdis(const string &str1,const string &str2)
{
int cnt=0,cb=0;
for(int i=0; i<m; i++)
{
if(str1[i]!=str2[i])
{
cnt++;
if(cnt>k) return false;
}else{
cb++;
if(cb>m-k)return false;
}
}
return cnt==k;
}
bool vis[200000+5];
int main()
{
scanf("%d%d%d",&n,&m,&k);
for(int i=1;i<=n;i++){
t[i]=i;
s[i]=i;
}
random_shuffle(s+1,s+n+1);
for(int i=1; i<=n; i++){
//cin>>str[i];
str[i].resize(m);
scanf("%s",&str[i][0]);
}
for(int i=1; i<=n; i++)
{
int y=s[i];
if(vis[y]) continue;
random_shuffle(t+1,t+n+1);
for(int j=1; j<=n; j++)
{
int x=t[j];
if(x==y) continue;
if(!getdis(str[y],str[x]))
{
vis[y]=vis[x]=true;
break;
}
}
if(!vis[y])
{
printf("%d\n",y);
return 0;
}
}
return 0;
}
详细
Test #1:
score: 0
Time Limit Exceeded
input:
3585 4096 2048 ABBBBBBAABAAAAAAAAAAAAABAABABBBABABAAAAABABAAAABAABAABBABBAABAABABBABAABBABBABABABBAAAABBABAABBBBABBBAABBBBBABAABAAABAAABBBBAAAABAABAABABABABBBBBABAAABAAABBAABABBABAABBAABBAABABBBBAABAAAABAABBABAAABBAAAAAABAABBABBABAABABBBAABABBABABBBAAAAABBBABABABBAABAAAABBBBABABAABBBABABABBAABBBABAB...