이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include<bits/stdc++.h>
using namespace std;
const int MAXN = 1e9;
int main(){
int n; cin>>n;
set<int> available;
for(int i = 1; i<=n; i++) available.insert(i);
vector<int> v(n); for(int& i : v) cin>>i;
for(int i : v){
if(available.count(i)) available.erase(i);
}
available.insert(MAXN);
int mx = 0;
int ans = 0;
for(int i = 0; i<n; i++){
if(v[i] == -1){
if(*available.upper_bound(mx) < MAXN){
ans++;
int t = *available.upper_bound(mx);
mx = t;
available.erase(t);
}
}
else{
if(v[i] > mx){
ans++; mx = v[i];
}
}
cout<<ans<<" ";
}
}
| # | 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... |