# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
385471 | taulant | Handcrafted Gift (IOI20_gift) | C++17 | 245 ms | 26708 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include<bits/stdc++.h>
using namespace std;
typedef pair<int, int> pii;
void craft(string& s);
int construct(int n, int r, vector<int> a, vector<int> b, vector<int> x){
vector<pii> one, two;
for(int i = 0; i < r; ++i){
if(x[i] == 1) one.push_back({a[i], b[i]});
if(x[i] == 2) two.push_back({a[i], b[i]});
}
sort(one.begin(), one.end());
sort(two.begin(), two.end());
string ans(n, 'R');
int f = 1;
for(auto [l, r] : one){
while(f <= l){
ans[f] = ans[f-1] == 'R'? 'B' : 'R';
++f;
}
while(f <= r){
ans[f] = ans[f-1];
++f;
}
}
while(f < n){
ans[f] = ans[f-1] == 'R'? 'B' : 'R';
++f;
}
// constructed a coloring, lets check if it is valid
vector<int> vld(two.size(), 1);
int diff = 1, idx = 0;
while(diff < n){
while(diff < n && ans[diff] == ans[diff - 1]) ++diff;
if(diff == n) break;
while(idx < two.size() && two[idx].first < diff){
if(two[idx].second >= diff) vld[idx] = 1;
++idx;
}
++diff;
}
for(int i : vld) if(!i) return 0;
craft(ans);
return 1;
}
컴파일 시 표준 에러 (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... |