Submission #532357

#TimeUsernameProblemLanguageResultExecution timeMemory
532357sepStove (JOI18_stove)C++14
100 / 100
50 ms2024 KiB
#include <iostream> #include <vector> #include <algorithm> using namespace std; int solve(int K, vector<int> & arrivals) { int N = (int)arrivals.size(); vector<int> gapSizes(N - 1); for (int i = 0; i < N - 1; i++) gapSizes[i] = arrivals[i+1]-arrivals[i]-1; sort(gapSizes.begin(), gapSizes.end(), greater<int>()); int answer = arrivals[N-1]+1 - arrivals[0]; for (int i = 0; i < K-1; i++) answer -= gapSizes[i]; return answer; } int main() { int N, K; vector<int> arrivals; cin >> N >> K; arrivals = vector<int>(N); for (int i = 0; i < N; i++) cin >> arrivals[i]; cout << solve(K, arrivals) << '\n'; return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...