# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
261717 | cheeheng | Colors (RMI18_colors) | C++14 | 176 ms | 3928 KiB |
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>
using namespace std;
typedef pair<int, int> ii;
vector<int> AdjList[150005];
int a[150005];
int b[150005];
ii ab[150005];
int deg[150005];
int main(){
int t;
scanf("%d", &t);
while(t --){
int N, M;
scanf("%d%d", &N, &M);
for(int i = 1; i <= N; i ++){
AdjList[i].clear();
deg[i] = 0;
}
set<int> s1;
for(int i = 1; i <= N; i ++){
scanf("%d", &a[i]);
s1.insert(a[i]);
}
for(int i = 1; i <= N; i ++){
scanf("%d", &b[i]);
}
for(int i = 0; i < M; i ++){
int u, v;
scanf("%d%d", &u, &v);
AdjList[u].push_back(v);
AdjList[v].push_back(u);
deg[u] ++;
deg[v] ++;
}
int ans = 1;
for(int i = 1; i <= N; i ++){
if(b[i] > a[i] || s1.find(b[i]) == s1.end()){
ans = 0;
break;
}
}
if(ans == 0){
printf("0\n");
continue;
}
int starVertex = -1;
for(int i = 1; i <= N; i ++){
if(deg[i] == N-1){
starVertex = i;
break;
}
}
if((long long)M == (long long)N*(N-1)/2){
multiset<int> s;
for(int i = 1; i <= N; i ++){
ab[i] = ii(a[i], b[i]);
s.insert(a[i]);
}
sort(ab+1, ab+(N+1), greater<ii>());
for(int i = 1; i <= N; i ++){
if(ab[i].first == ab[i].second){continue;}
if(ab[i].first < ab[i].second){
ans = 0;
break;
}
if(s.find(ab[i].second) != s.end()){
}else{
ans = 0;
break;
}
s.erase(s.find(ab[i].first));
}
printf("%d\n", ans);
continue;
}
if(starVertex != -1 && M == N-1){
for(int i = 1; i <= N; i ++){
if(i == starVertex){continue;}
if(b[i] <= a[starVertex] || b[i] == a[i]){
}else{
ans = 0;
break;
}
}
printf("%d\n", ans);
continue;
}
}
return 0;
}
Compilation message (stderr)
# | 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... |
# | 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... |