Submission #980056


Source Code Expand

#include <bits/stdc++.h>
using namespace std;

#define ms(s, n) memset(s, n, sizeof(s))
#define FOR(i, a, b) for (int i = (a); i < (b); i++)
#define FORd(i, a, b) for (int i = (a) - 1; i >= (b); i--)
#define FORall(it, a) for (__typeof((a).begin()) it = (a).begin(); it != (a).end(); it++)
#define sz(a) int((a).size())
#define present(t, x) (t.find(x) != t.end())
#define all(a) (a).begin(), (a).end()
#define uni(a) (a).erase(unique(all(a)), (a).end())
#define pb push_back
#define pf push_front
#define mp make_pair
#define fi first
#define se second
#define prec(n) fixed<<setprecision(n)
#define bit(n, i) (((n) >> (i)) & 1)
#define bitcount(n) __builtin_popcountll(n)
typedef long long ll;
typedef unsigned long long ull;
typedef long double ld;
typedef pair<int, int> pi;
typedef vector<int> vi;
typedef vector<pi> vii;
const int MOD = (int) 1e9 + 7;
const int INF = (int) 1e9;
const ll LINF = (ll) 1e18;
const ld PI = acos((ld) -1);
const ld EPS = 1e-9;
inline ll gcd(ll a, ll b) {ll r; while (b) {r = a % b; a = b; b = r;} return a;}
inline ll lcm(ll a, ll b) {return a / gcd(a, b) * b;}
inline ll fpow(ll n, ll k, int p = MOD) {ll r = 1; for (; k; k >>= 1) {if (k & 1) r = r * n % p; n = n * n % p;} return r;}
template<class T> inline int chkmin(T& a, const T& val) {return val < a ? a = val, 1 : 0;}
template<class T> inline int chkmax(T& a, const T& val) {return a < val ? a = val, 1 : 0;}
template<class T> inline T isqrt(T k) {T r = sqrt(k) + 1; while (r * r > k) r--; return r;}
template<class T> inline T icbrt(T k) {T r = cbrt(k) + 1; while (r * r * r > k) r--; return r;}
inline void addmod(int& a, int val, int p = MOD) {if ((a = (a + val)) >= p) a -= p;}
inline void submod(int& a, int val, int p = MOD) {if ((a = (a - val)) < 0) a += p;}
inline int mult(int a, int b, int p = MOD) {return (ll) a * b % p;}
inline int inv(int a, int p = MOD) {return fpow(a, p - 2, p);}

const int maxn = 100000 + 10;
int n, e, t;
int x[maxn];
int nxt[maxn];
long long f[maxn];
long long rmq[2][maxn << 1];

void upd(int k, int p, long long val) {
	for (rmq[k][p += maxn] = val; p > 1; ) p >>= 1, rmq[k][p] = min(rmq[k][p << 1], rmq[k][p << 1 | 1]);
}
long long query(int k, int l, int r) {
	long long res = LINF;
	for (l += maxn, r += maxn + 1; l < r; l >>= 1, r >>= 1) {
		if (l & 1) res = min(res, rmq[k][l++]);
		if (r & 1) res = min(res, rmq[k][--r]);
	}
	return res;
}

void solve() {
	cin >> n >> e >> t;
	FOR(i, 0, n) cin >> x[i];
	x[n] = e;
	for (int i = 0; i < (maxn << 1); i++) {
		rmq[0][i] = rmq[1][i] = LINF;
	}
	int ptr = 0;
	FOR(i, 0, n) {
		while (ptr < n - 1 && 2 * (x[ptr + 1] - x[i]) <= t) ptr++;
		nxt[i] = ptr;
	}
	upd(0, n, f[n] + x[n] + t);
	upd(1, n, f[n] + 2 * x[n - 1] + x[n]);
	FORd(i, n, 0) {
		int ix = nxt[i];
		f[i] = query(0, i + 1, ix + 1) - x[i];
		chkmin(f[i], query(1, ix + 2, n) - 3 * x[i]);
		if (i) {
			upd(0, i, f[i] + x[i] + t);
			upd(1, i, f[i] + 2 * x[i - 1] + x[i]);
		}
	}
	cout << f[0] + x[0] << "\n";
}

int main() {
	ios_base::sync_with_stdio(0); cin.tie(0);
#ifdef _LOCAL_
	freopen("in.txt", "r", stdin); //freopen("out.txt", "w", stdout);
#endif
	solve();
#ifdef _LOCAL_
	//printf("\nTime elapsed: %dms", 1000 * clock() / CLOCKS_PER_SEC);
#endif
	return 0;
}

Submission Info

Submission Time
Task D - Shik and Game
User chemthan
Language C++14 (GCC 5.4.1)
Score 600
Code Size 3312 Byte
Status WA
Exec Time 38 ms
Memory 5120 KB

Judge Result

Set Name Sample Subtask1 All
Score / Max Score 0 / 0 600 / 600 0 / 600
Status
AC × 3
AC × 23
AC × 35
WA × 29
Set Name Test Cases
Sample 0_00.txt, 0_01.txt, 0_02.txt
Subtask1 0_00.txt, 0_01.txt, 0_02.txt, 1_00.txt, 1_01.txt, 1_02.txt, 1_03.txt, 1_04.txt, 1_05.txt, 1_06.txt, 1_07.txt, 1_08.txt, 1_09.txt, 1_10.txt, 1_11.txt, 1_12.txt, 1_13.txt, 1_14.txt, 1_15.txt, 1_16.txt, 1_17.txt, 1_18.txt, 1_19.txt
All 0_00.txt, 0_01.txt, 0_02.txt, 1_00.txt, 1_01.txt, 1_02.txt, 1_03.txt, 1_04.txt, 1_05.txt, 1_06.txt, 1_07.txt, 1_08.txt, 1_09.txt, 1_10.txt, 1_11.txt, 1_12.txt, 1_13.txt, 1_14.txt, 1_15.txt, 1_16.txt, 1_17.txt, 1_18.txt, 1_19.txt, 2_00.txt, 2_01.txt, 2_02.txt, 2_03.txt, 2_04.txt, 2_05.txt, 2_06.txt, 2_07.txt, 2_08.txt, 2_09.txt, 2_10.txt, 2_11.txt, 2_12.txt, 2_13.txt, 2_14.txt, 2_15.txt, 2_16.txt, 2_17.txt, 2_18.txt, 2_19.txt, 2_20.txt, 2_21.txt, 2_22.txt, 2_23.txt, 2_24.txt, 2_25.txt, 2_26.txt, 2_27.txt, 2_28.txt, 2_29.txt, 2_30.txt, 2_31.txt, 2_32.txt, 2_33.txt, 2_34.txt, 2_35.txt, 2_36.txt, 2_37.txt, 2_38.txt, 2_39.txt, 2_40.txt
Case Name Status Exec Time Memory
0_00.txt AC 6 ms 3328 KB
0_01.txt AC 6 ms 3328 KB
0_02.txt AC 6 ms 3456 KB
1_00.txt AC 6 ms 3456 KB
1_01.txt AC 6 ms 3456 KB
1_02.txt AC 6 ms 3456 KB
1_03.txt AC 6 ms 3456 KB
1_04.txt AC 6 ms 3456 KB
1_05.txt AC 6 ms 3456 KB
1_06.txt AC 6 ms 3456 KB
1_07.txt AC 6 ms 3456 KB
1_08.txt AC 6 ms 3456 KB
1_09.txt AC 6 ms 3456 KB
1_10.txt AC 6 ms 3456 KB
1_11.txt AC 6 ms 3456 KB
1_12.txt AC 6 ms 3456 KB
1_13.txt AC 6 ms 3456 KB
1_14.txt AC 6 ms 3456 KB
1_15.txt AC 6 ms 3456 KB
1_16.txt AC 6 ms 3456 KB
1_17.txt AC 6 ms 3456 KB
1_18.txt AC 6 ms 3456 KB
1_19.txt AC 6 ms 3456 KB
2_00.txt AC 30 ms 4992 KB
2_01.txt AC 30 ms 4992 KB
2_02.txt AC 30 ms 4992 KB
2_03.txt AC 30 ms 4992 KB
2_04.txt AC 30 ms 4992 KB
2_05.txt AC 30 ms 4992 KB
2_06.txt AC 30 ms 4992 KB
2_07.txt AC 30 ms 4992 KB
2_08.txt AC 30 ms 4992 KB
2_09.txt AC 30 ms 4992 KB
2_10.txt WA 31 ms 4992 KB
2_11.txt WA 31 ms 4992 KB
2_12.txt WA 31 ms 4992 KB
2_13.txt WA 31 ms 5120 KB
2_14.txt WA 31 ms 4992 KB
2_15.txt WA 31 ms 4992 KB
2_16.txt WA 31 ms 4992 KB
2_17.txt WA 31 ms 4992 KB
2_18.txt WA 31 ms 4992 KB
2_19.txt WA 32 ms 4992 KB
2_20.txt WA 32 ms 4992 KB
2_21.txt WA 32 ms 4992 KB
2_22.txt WA 33 ms 4992 KB
2_23.txt WA 33 ms 4992 KB
2_24.txt WA 34 ms 4992 KB
2_25.txt WA 35 ms 4992 KB
2_26.txt WA 36 ms 4992 KB
2_27.txt WA 38 ms 4992 KB
2_28.txt WA 37 ms 4992 KB
2_29.txt WA 37 ms 4992 KB
2_30.txt WA 37 ms 4992 KB
2_31.txt WA 38 ms 4992 KB
2_32.txt WA 38 ms 4992 KB
2_33.txt WA 38 ms 4992 KB
2_34.txt WA 38 ms 4992 KB
2_35.txt WA 37 ms 4992 KB
2_36.txt WA 37 ms 4992 KB
2_37.txt WA 37 ms 4992 KB
2_38.txt WA 37 ms 4992 KB
2_39.txt AC 36 ms 5120 KB
2_40.txt AC 35 ms 4992 KB