QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#667153 | #9246. Dominating Point | wysun | RE | 0ms | 0kb | C++14 | 1.4kb | 2024-10-22 21:16:45 | 2024-10-22 21:17:22 |
Judging History
answer
#include<iostream>
#include<vector>
#include<cstring>
using namespace std;
const int N=5e5+10;
bool m[N][N];
int a,b,c;
int s[N];
int main()
{
int n;
cin>>n;
int a,maxa=0;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
char ch;
cin>>ch;
m[i][j] = (ch == '1');
s[i] += (ch == '1');
}
if(maxa<s[i])
{
maxa = s[i];
a = i;
}
}
if(maxa == n - 1)
{
cout<<"NOT FOUND"<<endl;
return 0;
}
vector<int> v;
for(int i=1;i<=n;i++)
if(m[i][a])
v.push_back(i);
int maxb=0,b;
memset(s,0,sizeof s);
for(auto x : v)
{
for(auto y : v)
{
if(m[x][y])
s[x] ++;
}
if(s[x]>maxb)
{
maxb = s[x];
b=x;
}
}
int c;
if(maxb != v.size() - 1)
{
vector<int> w;
for(auto x : v)
if(m[x][b])
w.push_back(x);
int maxc=0;
memset(s,0,sizeof s);
for(auto x : w)
{
for(auto y : w)
if(m[x][y])
s[x]++;
if(maxc < s[x])
{
c = x;
maxc = s[x];
}
}
}
else
{
vector<int> w;
for(int j=1;j<=n;j++)
if(m[a][j])
w.push_back(j);
int maxc=0;
memset(s,0,sizeof s);
for(auto x : w)
{
for(auto y : w)
if(m[x][y])
s[x]++;
if(maxc < s[x])
{
c = x;
maxc = s[x];
}
}
}
cout<<a<<' '<<b<<' '<<c<<endl;
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 0
Runtime Error
input:
6 011010 000101 010111 100001 010100 100010