Submission #533234

#TimeUsernameProblemLanguageResultExecution timeMemory
533234devariaotaMoney (IZhO17_money)C++17
45 / 100
1577 ms11480 KiB
#include <bits/stdc++.h>
using namespace std;
#define ll long long

int n;
int lst[1000005];
vector<int> arr;
map <int, bool> mp; 

int binser(int x) {
  int l = 0, r = arr.size(), ans = -1;
  r--;
  while(l <= r) {
    int mid = (l + r) / 2;
    if (arr[mid] <= x) {
      ans = mid;
      l = mid + 1;
    }
    else {
      r = mid - 1;
    }
  }
  return ans;
}

int main() {
  cin >> n;
  for(int i = 1; i <= n; i++) {
    cin >> lst[i];
  }
  
  int l = 1;
  int ans = 0;
  while(l <= n) {
    //cout << "::" << l << endl;
    ans++;
    int loc = binser(lst[l]);
    int r = l + 1;
    while(r <= n && lst[r] >= lst[r - 1]) {
      int loc1 = binser(lst[r]);
      
      //cout << r << " " << loc << " " << loc1 << endl;
      if (loc1 >= 0 && lst[r] == arr[loc1] && loc == loc1 - 1) {
        loc1--;
      }
      if (loc == loc1) {
        r++;
      }
      else {
        break;
      }
    }
    for(int i = l; i < r; i++) {
      if (mp.count(lst[i])) {
        continue;
      }
      mp.insert({lst[i], true});
      arr.push_back(lst[i]);
    }
    sort(arr.begin(), arr.end());
    l = r;
  }
  cout << ans;
}

#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...