Submission #1000652

#TimeUsernameProblemLanguageResultExecution timeMemory
1000652vjudge1Safety (NOI18_safety)C++17
100 / 100
37 ms4704 KiB
//#pragma GCC target("sse,sse2,sse3,ssse3,sse4,popcnt,abm,mmx,avx,tune=native")
//#pragma GCC optimize("Ofast,unroll-loops,fast-math,O3")
 
#include<bits/stdc++.h>	
 
using namespace std;
 
#define all(a) a.begin(), a.end()                                                   
#define rall(a) a.rbegin(), a.rend()                 
#define sz(a) (int)a.size()
#define s second
#define f first
 
using ll = long long;
using pii = pair<int, int>;
using pll = pair<ll, ll>;
 
mt19937_64 rng(chrono::steady_clock::now().time_since_epoch().count());
     
vector<pii> rid = {{0, 1}, {0, -1}, {1, 0}, {-1, 0}};
vector<pii> dir = {{-1, -1}, {-1, 1}, {1, -1}, {1, 1}};
 
const int N = 1e6 + 1, mod = 998244353;
 
const ll inf = 1e9;
 
double eps = 1e-15;
                                                
bool flg = 0;

void slv() {
	ll n, h;
	cin >> n >> h;
	int s[n];
	for (int i = 0; i < n; i++) cin >> s[i];
	priority_queue<ll> tl, tr;
	ll ans = 0;
	tl.push(s[0]);
	tr.push(-s[0]);
	for (int i = 1; i < n; i++) {
		ll x = tl.top() - h * i;
		ll y = (-tr.top()) + h * i;
		if (x <= s[i] && s[i] <= y) {
			tl.push(s[i] + h * i);
			tr.push(-(s[i] - h * i));
		}else if (y < s[i]) {
			tr.pop();
			tl.push(y + h * i);
			tr.push(-(s[i] - h * i));
			tr.push(-(s[i] - h * i));
			ans += (s[i] - y);
		}else {
			tl.pop();
			tr.push(-(x - h * i));
			tl.push(s[i] + h * i);
			tl.push(s[i] + h * i);
			ans += (x - s[i]);
		}
	}	
	cout << ans;
}       	                                                                    
 
main() {
	//freopen("input.txt", "r", stdin);                                                                                     
	//freopen("output.txt", "w", stdout);                                                                                     
	ios_base::sync_with_stdio(0);	                                                                                       
	cin.tie(0);
	int tp = 1;
	if (flg) cin >> tp;
	while (tp--) {  	
		slv();
	}
}
//wenomechainsama      

Compilation message (stderr)

safety.cpp:63:1: warning: ISO C++ forbids declaration of 'main' with no type [-Wreturn-type]
   63 | main() {
      | ^~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...