// ConsoleApplication134.cpp : This file contains the 'main' function. Program execution begins and ends there.
//
#include <iostream>
using namespace std;
#include <vector>
#define vi vector<int>
#define pi pair<int,int>
#define ll long long
#include <algorithm>
#include <queue>
#define pll pair<ll,ll>
const int siz = 2e5;
bool ans[siz];
ll cit[siz];
vi fr[siz];
int up[siz];
#include <set>
vector<pll> ord;
int my[siz];
vi col[siz];
ll sum[siz];
set<pll> out[siz];
int num[siz];
void uni(int i, int j) {
if (my[i] == my[j])return;
if (out[my[i]].size() < out[my[j]].size()) {
swap(out[my[i]], out[my[j]]);
}
if (col[my[i]].size() < col[my[j]].size()) {
swap(col[my[i]], col[my[j]]);
}
for (int v : col[my[j]]) {
col[my[i]].push_back(v);
}
for (pll p : out[my[j]]) {
out[my[i]].insert(p);
}
sum[my[i]] += sum[my[j]];
for (int v : col[my[j]]) {
my[v] = my[i];
}
}
int main()
{
int n, m;
cin >> n >> m;
for (int i = 0; i < n; i++) {
cin >> cit[i];
ord.push_back({ cit[i],i });
}
for (int i = 0; i < m; i++) {
int a, b;
cin >> a >> b;
a--, b--;
fr[a].push_back(b);
fr[b].push_back(a);
}
sort(ord.begin(), ord.end());
ans[ord[n - 1].second] = 1;
for (int i = 0; i < n; i++) {
num[ord[i].second] = i;
}
for (int i = 0; i < n; i++) {
my[i] = i;
col[i].push_back(i);
sum[i] = cit[i];
for (int f : fr[i]) {
pi p1 = { cit[f],num[f] }, p2 = { cit[i], num[i] };
if ( p1>p2 ) {
out[i].insert({ cit[f],f });
}
}
}
for (int i = 0; i < n; i++)up[i] = -1;
for (int i = 0; i < n; i++) {
int j = ord[i].second;
for (int f : fr[j]) {
if (out[my[f]].find({ cit[j],j }) != out[my[f]].end()) {
out[my[f]].erase({ cit[j],j });
}
}
for (int f : fr[j]) {
pi p1 = { cit[f],num[f] }, p2 = { cit[j], num[j] };
if (p2 >= p1) {
uni(j, f);
}
}
if (!out[my[j]].empty()) {
pll p = *out[my[j]].begin();
if (p.first <= sum[my[j]]) {
up[j] = p.second;
}
}
}
for (int i = n - 2; i >= 0; i--) {
if (up[ord[i].second] != -1) {
ans[ord[i].second] = ans[up[ord[i].second]];
}
}
for (int i = 0; i < n; i++)if (ans[i])cout << '1'; else cout << '0';
}
// Run program: Ctrl + F5 or Debug > Start Without Debugging menu
// Debug program: F5 or Debug > Start Debugging menu
// Tips for Getting Started:
// 1. Use the Solution Explorer window to add/manage files
// 2. Use the Team Explorer window to connect to source control
// 3. Use the Output window to see build output and other messages
// 4. Use the Error List window to view errors
// 5. Go to Project > Add New Item to create new code files, or Project > Add Existing Item to add existing code files to the project
// 6. In the future, to open this project again, go to File > Open > Project and select the .sln file
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
10 ms |
19068 KB |
Output is correct |
2 |
Correct |
10 ms |
19028 KB |
Output is correct |
3 |
Correct |
10 ms |
19028 KB |
Output is correct |
4 |
Incorrect |
13 ms |
19444 KB |
Output isn't correct |
5 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
10 ms |
19012 KB |
Output is correct |
2 |
Correct |
11 ms |
19048 KB |
Output is correct |
3 |
Correct |
371 ms |
55036 KB |
Output is correct |
4 |
Incorrect |
328 ms |
53240 KB |
Output isn't correct |
5 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
10 ms |
19028 KB |
Output is correct |
2 |
Incorrect |
518 ms |
53292 KB |
Output isn't correct |
3 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
10 ms |
19028 KB |
Output is correct |
2 |
Incorrect |
590 ms |
53300 KB |
Output isn't correct |
3 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
10 ms |
19068 KB |
Output is correct |
2 |
Correct |
10 ms |
19028 KB |
Output is correct |
3 |
Correct |
10 ms |
19028 KB |
Output is correct |
4 |
Incorrect |
13 ms |
19444 KB |
Output isn't correct |
5 |
Halted |
0 ms |
0 KB |
- |