# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
1112275 | Matbubble | Stove (JOI18_stove) | C++14 | 0 ms | 0 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <iostream>
#include <iomanip>
#include <string>
#include <math.h>
#include <algorithm>
#include <cstring>
#include <numeric>
#include <vector>
#include <bitset>
#include <map>
#include <set>
#include <queue>
#include <deque>
#include <stack>
#include <unordered_map>
#include <unordered_set>
using namespace std;
#define dbg(x) cerr<<#x<<": "<<x<<"\n";
/*
I love DP
*/
const long long maxN=2e5;
long long arr[maxN+1];
void solve(){
long long n, k; cin>>n>>k;
for(long long i=0 ; i<n ; i++) cin>>arr[i];
long long ans=arr[n-1]-arr[0]+1;
vector<long long>v;
for(long long i=0 ; i<n-1 ; i++){
v.push_back(arr[i+1]-1-arr[i]);
}
sort(v.begin(), v.end(), greater<long long>());
for(long long i=0 ; i<k-1; i++) ans-=v[i];
cout<<ans<<"\n";
}
long long main(){
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
solve();
return 0;
}