#include using namespace std; template inline bool chmax(T &a, T b) { if (a < b) { a = b; return 1; } return 0; } template inline bool chmin(T &a, T b) { if (a > b) { a = b; return 1; } return 0; } typedef long long int ll; #define EPS (1e-7) #define INF (1 << 30) #define LLINF (1LL << 60) #define PI (acos(-1)) #define MOD (1000000007) #define ALL(v) (v).begin(), (v).end() #define RALL(v) (v).rbegin(), (v).rend() const int dx[4] = {1, 0, -1, 0}; const int dy[4] = {0, 1, 0, -1}; //------------------------------------- struct RSQ { private: ll n; vector node; public: RSQ(vector &v) { ll sz = v.size(); n = 1; while (n < sz) { n *= 2; } node.resize(2 * n - 1, 0); for (ll i = 0; i < sz; i++) { node[i + n - 1] = v[i]; } for (ll i = n - 2; i >= 0; i--) { node[i] = node[2 * i + 1] + node[2 * i + 2]; } } void add(ll x, ll val) { x += (n - 1); node[x] += val; while (x > 0) { x = (x - 1) / 2; node[x] = node[2 * x + 1] + node[2 * x + 2]; } } ll getsum(ll a, ll b, ll now = 0, ll l = 0, ll r = -1) { if (r < 0) { r = n; } if (r <= a || l >= b) { return 0; } if (a <= l && r <= b) { return node[now]; } ll vl = getsum(a, b, 2 * now + 1, l, (l + r) / 2); ll vr = getsum(a, b, 2 * now + 2, (l + r) / 2, r); return vl + vr; } }; int main() { cin.tie(0); ios::sync_with_stdio(false); ll n, k; cin >> n >> k; const ll mxw = 1000000; vector a(mxw + 1); // a[i] := 重さiの荷物の個数 RSQ seg(a); for (ll i = 0; i < n; i++) { ll w; cin >> w; if (w > 0) { if (seg.getsum(w, mxw + 1) < k) { seg.add(w, 1); } } else { w = -w; if (seg.getsum(1, w + 1) - seg.getsum(1, w) > 0) { seg.add(w, -1); } } } ll ans = seg.getsum(1, mxw + 1); cout << ans << endl; }