This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
#define min(x,y) (x>=y?y:x)
#define max(x,y) ((x)>=(y)?(x):(y))
#define xc3(x) (x*(x-1)*(x-2)/6)
#define xc2(x) (x*(x-1)/2)
#define GF G[node][i].first
#define s0b stk[0].begin()
#define s0e stk[0].end()
#define s1b stk[1].begin()
#define s1e stk[1].end()
using namespace std;
#define ll long long
#define ull unsigned long long
int N,M,V;
vector<int> type;
vector<vector<int>> adjlistGBYKTR;
vector<int> par,sizev;
int finds(int a){
if(a==par[a])return a;
return par[a] = finds(par[a]);
}
void make_union(int a,int b){
a=finds(a);
b=finds(b);
if(a!=b){
if(sizev[a]<sizev[b]){
swap(a,b);
}
par[b]=a;
sizev[a]+=sizev[b];
}
}
void PAL(int node,int deg){
int p = finds(node);
for(int i=0;i<M;i++){
if(finds(i)!=p)continue;
type[i]=N-deg+1;
}
}
bool DFS(int deg,int node){
if(type[node]==deg)return true;
if(deg==N){PAL(node,deg);return true;}
for(int i=0;i<adjlistGBYKTR[node].size();i++){
bool c = DFS(deg+1,adjlistGBYKTR[node][i]);
if(c && type[node]==-1)PAL(node,deg);
}
return (type[node]==deg);
}
int main()
{
cin>>N>>M>>V;
type.assign(M,-1);
vector<int> countt(M,0);
adjlistGBYKTR = vector<vector<int>>(M,vector<int>(0));
par = vector<int>(M);iota(par.begin(),par.end(),0);
sizev = vector<int>(M,1);
for(int i=0;i<V;i++){
string s;cin>>s;
vector<string> a(2,"");int w=0;char t='c';
for(int j=0;j<s.size();j++){
if(s[j]=='=' || s[j]=='<'){
w++;
t=s[j];
}
else a[w]+=s[j];
}
int i1=stoi(a[0]),i2=stoi(a[1]);i1--;i2--;
if(t=='='){
make_union(i1,i2);
}
else{
adjlistGBYKTR[i2].push_back(i1);
countt[i1]++;
}}
for(int i=0;i<M;i++){
if(countt[i]!=0)continue;
DFS(1,i); // deg , node , parent
}
for(int i=0;i<M;i++){
if(type[i]==-1)cout<<"?"<<endl;
else{
cout<<"K"<<type[i]<<endl;
}
}
}
Compilation message (stderr)
kovanice.cpp: In function 'bool DFS(int, int)':
kovanice.cpp:44:15: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
44 | for(int i=0;i<adjlistGBYKTR[node].size();i++){
| ~^~~~~~~~~~~~~~~~~~~~~~~~~~~
kovanice.cpp: In function 'int main()':
kovanice.cpp:62:16: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
62 | for(int j=0;j<s.size();j++){
| ~^~~~~~~~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |