제출 #574582

#제출 시각아이디문제언어결과실행 시간메모리
574582beabossRabbit Carrot (LMIO19_triusis)C++14
0 / 100
0 ms212 KiB
#include <bits/stdc++.h>

using namespace std;


typedef long long ll;

ll mod = 1000000007;


int main() {
	ll n, m;
	cin >> n >> m;

	vector<ll> vals(n);

	for (ll i = 0; i < n; i++) {
		cin >> vals[i];
	}

	vector<ll> dp(n + 1, 0);
	
    for (ll i = 0; i < n; i++) {
    	
    	if (m * (i + 1) < vals[i]) continue;

    	ll best = -1;
    	ll best_s = 0;

    	for (ll j = 0; j < i; j++) {
    		if (vals[i] > vals[j] + m * (i - j)) continue;
    		if (dp[j + 1] >= best_s) {
    			best_s = dp[j + 1];
    			best = j;
    		}
    	}

    	dp[i + 1] = 1 + dp[best + 1];
        
        
		
    }

    cout << n - dp[n] << endl;
}

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