Submission #971535

#TimeUsernameProblemLanguageResultExecution timeMemory
971535CyberCowThe short shank; Redemption (BOI21_prison)C++17
10 / 100
47 ms14164 KiB
#include <random> #include <algorithm> #include <bitset> #include <chrono> #include <cmath> #include <deque> #include <fstream> #include <iomanip> #include <iostream> #include <iterator> #include <map> #include <queue> #include <set> #include <stack> #include <string> #include <unordered_map> #include <unordered_set> #include <vector> #include <chrono> #define m_p make_pair #define all(x) (x).begin(),(x).end() #define sz(x) ((x).size()) typedef long long ll; using ull = unsigned long long; using namespace std; mt19937 rnd(348502); ll mod1 = 998244353; ll mod = 1e9 + 7; const ll N = 500010; int a[N], lr[N]; int han[N]; int ans[N]; int achqisjoga[N]; void solve() { int n, d, k, t; cin >> n >> d >> t; for (int i = 1; i <= n; i++) { cin >> a[i]; if (a[i] <= t) lr[i] = min(t - a[i] + i, n); } stack<pair<int, int>> se; int obshi = 0; for (int i = 1; i <= n; i++) { se.push({ i, lr[i] }); while (!se.empty() && se.top().second < i) { se.pop(); } if (!se.empty()) { han[i] = se.top().first; achqisjoga[se.top().first]++; achqisjoga[i]--; ans[se.top().first]++; obshi++; } } int ma = 0, qaq = 0; for (int i = 1; i <= n; i++) { qaq += achqisjoga[i]; ma = max(ma, qaq); } cout << obshi - ma; } int main() { ios_base::sync_with_stdio(false); cin.tie(0); int tt = 1; //cin >> tt; while (tt--) { solve(); } return 0; }

Compilation message (stderr)

prison.cpp: In function 'void solve()':
prison.cpp:38:15: warning: unused variable 'k' [-Wunused-variable]
   38 |     int n, d, k, t;
      |               ^
#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...