제출 #1135075

#제출 시각아이디문제언어결과실행 시간메모리
1135075AvianshSafety (NOI18_safety)C++20
40 / 100
1817 ms327680 KiB
#include <bits/stdc++.h> using namespace std; signed main(){ ios::sync_with_stdio(0); cin.tie(0); int n,h; cin >> n >> h; int arr[n]; int mxval = 0; for(int &i : arr){ cin >> i; mxval=max(mxval,i); } if(n==1){ cout << 0; return 0; } if(h==0){ sort(arr,arr+n); int mid = 0; if(n%2==0){ mid = (arr[n/2]+arr[n/2-1])/2; } else{ mid=arr[n/2]; } long long ans = 0; for(int i = 0;i<n;i++){ ans+=abs(mid-arr[i]); } cout << ans; return 0; } int dp[n][mxval+1]; for(int i = 0;i<=mxval;i++){ dp[0][i]=abs(i-arr[0]); } for(int i = 1;i<n;i++){ multiset<int>s; for(int j = 0;j<=min(h-1,mxval);j++){ s.insert(dp[i-1][j]); } for(int j = 0;j<=mxval;j++){ if(j+h<=mxval){ s.insert(dp[i-1][j+h]); } if(j-h-1>=0){ s.erase(s.find(dp[i-1][j-h-1])); } dp[i][j]=abs(arr[i]-j)+(*(s.begin())); } } cout << *min_element(dp[n-1],dp[n-1]+mxval+1); return 0; }
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...