Submission #1119862

#TimeUsernameProblemLanguageResultExecution timeMemory
1119862peacebringer1667Solar Storm (NOI20_solarstorm)C++17
28 / 100
275 ms114444 KiB
#include<bits/stdc++.h> #define ll long long #define ldb long double #define db double #define fi first #define se second #define sza(a) (int)a.size() #define pir pair<int,int> #define pirll pair<ll,ll> using namespace std; const int alp = 20; const int maxn = 1e6 + 5; template <typename t> inline void mini(t &x,t y){if (x > y) x = y;} template <typename t> inline void maxi(t &x,t y){if (x < y) x = y;} template <typename t> inline bool maximized(t &x,t y){if (x < y){x = y; return 1;}return 0;} int spt[maxn][alp + 2],nxt[maxn]; ll dist[maxn],V[maxn]; void input(int n,int s,ll k){ for (int i = 2 ; i <= n ; i++) cin >> dist[i]; for (int i = 1 ; i <= n ; i++) cin >> V[i]; } void prepare(int n,ll k){ //prepare distance and sum of value->V for (int i = 2 ; i <= n ; i++){ dist[i] += dist[i - 1]; V[i] += V[i - 1]; } //prepare maximum point from i,dist(i->p) <= k int p = n; for (int i = n ; i > 0 ; i--){ while (p > i && dist[p] - dist[i] > k) p--; nxt[i] = p; } //preparing sparse table //initialize to n + 1 for (int i = 1 ; i <= n + 1 ; i++) for (int j = 0 ; j <= alp ; j++) spt[i][j] = n + 1; //next point p : a machine is placed->(i->p - 1) for (int i = n ; i > 0 ; i--){ int p = nxt[nxt[i]] + 1; spt[i][0] = p; for (int j = 1 ; j <= alp ; j++) spt[i][j] = spt[spt[i][j - 1]][j - 1]; } } ll profit(int x,int n,int s){ int y = x; for (int i = alp ; i >= 0 ; i--) if (s >= (1 << i)){ y = spt[y][i]; s -= (1 << i); } return V[y - 1] - V[x - 1]; } void solve(int n,int s){ ll max_profit = 0; int start = 1; for (int i = 1 ; i <= n ; i++) if (maximized(max_profit,profit(i,n,s))) start = i; cout << profit << "\n"; while (s > 0 && start <= n){ cout << nxt[start] << " "; s--; start = nxt[nxt[start]] + 1; } } int main(){ ios_base::sync_with_stdio(false); cin.tie(0);cout.tie(0); int n,s;ll k; cin >> n >> s >> k; input(n,s,k); prepare(n,k); //k is not important, as exhausted using sparse table and nxt solve(n,s); return 0; }

Compilation message (stderr)

SolarStorm.cpp: In function 'void solve(int, int)':
SolarStorm.cpp:79:10: warning: the address of 'long long int profit(int, int, int)' will never be NULL [-Waddress]
   79 |  cout << profit << "\n";
      |          ^~~~~~
#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...