| 16193 | 2025-04-14 14:44:23 | zsombor | Növekvő Ödön és a Másoló Varázsló | cpp17 | Hibás válasz 95/100 | 177ms | 7156 KiB |
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
int n, m, ans;
vector <int> a(5e5, 0);
vector <int> b;
vector <int> dp(5e5, 1e9);
vector <int> f(5e5, 1e9);
int gr(int x) {
return b.end() - lower_bound(b.begin(), b.end(), x);
}
int pos(int k) {
return n + m - k - gr(a[k]);
}
void update(int k) {
int x = pos(k);
for (int i = x; i < f.size(); i = (i | (i + 1))) f[i] = min(f[i], dp[k]);
}
void query(int k) {
int x = pos(k) + 1;
for (int i = x; i >= 0; i = (i & (i + 1)) - 1) dp[k] = min(dp[k], f[i]);
dp[k]--;
if (gr(a[k]) >= n - k) ans = min(ans, dp[k]);
}
int main() {
ios_base::sync_with_stdio(false);
cin.tie(NULL);
cin >> n >> m;
for (int i = 1; i <= n; i++) cin >> a[i];
b.resize(m);
for (int& i : b) cin >> i;
sort(b.begin(), b.end());
ans = m;
dp[0] = n;
for (int i = 1; i <= n; i++) {
if (a[i - 1] < a[i]) dp[i] = dp[i - 1];
query(i);
update(i - 1);
}
cout << ans << "\n";
/*for (int i = 0; i <= n; i++) cout << pos(i) << " ";
cout << "\n";
for (int i = 0; i <= n; i++) cout << dp[i] << " ";*/
}| Részfeladat | Összpont | Teszt | Verdikt | Idő | Memória | ||
|---|---|---|---|---|---|---|---|
| subtask1 | 0/0 | ||||||
| 1 | Elfogadva | 6ms | 6196 KiB | ||||
| 2 | Elfogadva | 37ms | 6452 KiB | ||||
| subtask2 | 0/5 | ||||||
| 3 | Elfogadva | 52ms | 7156 KiB | ||||
| 4 | Elfogadva | 52ms | 7156 KiB | ||||
| 5 | Hibás válasz | 52ms | 6964 KiB | ||||
| subtask3 | 10/10 | ||||||
| 6 | Elfogadva | 7ms | 6196 KiB | ||||
| 7 | Elfogadva | 6ms | 6196 KiB | ||||
| 8 | Elfogadva | 6ms | 6196 KiB | ||||
| subtask4 | 15/15 | ||||||
| 9 | Elfogadva | 7ms | 6144 KiB | ||||
| 10 | Elfogadva | 6ms | 6272 KiB | ||||
| 11 | Elfogadva | 6ms | 6116 KiB | ||||
| 12 | Elfogadva | 7ms | 6136 KiB | ||||
| subtask5 | 5/5 | ||||||
| 13 | Elfogadva | 8ms | 6196 KiB | ||||
| 14 | Elfogadva | 8ms | 6340 KiB | ||||
| 15 | Elfogadva | 8ms | 6196 KiB | ||||
| subtask6 | 5/5 | ||||||
| 16 | Elfogadva | 8ms | 6196 KiB | ||||
| 17 | Elfogadva | 8ms | 6388 KiB | ||||
| 18 | Elfogadva | 8ms | 6228 KiB | ||||
| 19 | Elfogadva | 8ms | 6196 KiB | ||||
| subtask7 | 10/10 | ||||||
| 20 | Elfogadva | 8ms | 6336 KiB | ||||
| 21 | Elfogadva | 8ms | 6196 KiB | ||||
| 22 | Elfogadva | 9ms | 6272 KiB | ||||
| 23 | Elfogadva | 7ms | 6328 KiB | ||||
| 24 | Elfogadva | 8ms | 6196 KiB | ||||
| subtask8 | 25/25 | ||||||
| 25 | Elfogadva | 63ms | 6452 KiB | ||||
| 26 | Elfogadva | 61ms | 6452 KiB | ||||
| 27 | Elfogadva | 64ms | 6704 KiB | ||||
| 28 | Elfogadva | 4ms | 6200 KiB | ||||
| 29 | Elfogadva | 86ms | 6640 KiB | ||||
| 30 | Elfogadva | 61ms | 6588 KiB | ||||
| 31 | Elfogadva | 61ms | 6724 KiB | ||||
| 32 | Elfogadva | 63ms | 6452 KiB | ||||
| 33 | Elfogadva | 64ms | 6568 KiB | ||||
| 34 | Elfogadva | 65ms | 6572 KiB | ||||
| 35 | Elfogadva | 67ms | 6452 KiB | ||||
| 36 | Elfogadva | 61ms | 6708 KiB | ||||
| 37 | Elfogadva | 61ms | 6712 KiB | ||||
| 38 | Elfogadva | 68ms | 6452 KiB | ||||
| 39 | Elfogadva | 86ms | 6708 KiB | ||||
| 40 | Elfogadva | 68ms | 6708 KiB | ||||
| 41 | Elfogadva | 68ms | 6572 KiB | ||||
| 42 | Elfogadva | 39ms | 6588 KiB | ||||
| 43 | Elfogadva | 61ms | 6708 KiB | ||||
| 44 | Elfogadva | 61ms | 6564 KiB | ||||
| 45 | Elfogadva | 64ms | 6572 KiB | ||||
| subtask9 | 25/25 | ||||||
| 46 | Elfogadva | 119ms | 6964 KiB | ||||
| 47 | Elfogadva | 127ms | 7156 KiB | ||||
| 48 | Elfogadva | 118ms | 6964 KiB | ||||
| 49 | Elfogadva | 175ms | 7080 KiB | ||||
| 50 | Elfogadva | 177ms | 7084 KiB | ||||
| 51 | Elfogadva | 177ms | 7088 KiB | ||||
| 52 | Elfogadva | 107ms | 6964 KiB | ||||
| 53 | Elfogadva | 116ms | 6964 KiB | ||||
| 54 | Elfogadva | 125ms | 7076 KiB | ||||
| 55 | Elfogadva | 127ms | 6964 KiB | ||||