#include <iostream>
using namespace std;
int n, k, a[1003], res;
bool changed = true;
int main(){
ios::sync_with_stdio(false);
cin.tie(NULL);
cin>>n>>k;
for(int i = 1 ; i <= n; i++){
cin >> a[i];
}
while(changed){
changed = false;
for(int i = 1; i <= n; i++){
if (a[i+1] - a[i] > k){
res+=a[i+1] - (a[i] + k);
a[i] = a[i+1] - k;
changed = true;
}
if (a[i-1] - a[i] > k){
res+=a[i-1] - (a[i] + k);
a[i] = a[i-1] - k;
changed = true;
}
}
}
cout<<res<<endl;
}
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | #include <iostream> using namespace std; int n, k, a[1003], res; bool changed = true; int main(){ ios::sync_with_stdio(false); cin.tie(NULL); cin>>n>>k; for(int i = 1 ; i <= n; i++){ cin >> a[i]; } while(changed){ changed = false; for(int i = 1; i <= n; i++){ if (a[i+1] - a[i] > k){ res+=a[i+1] - (a[i] + k); a[i] = a[i+1] - k; changed = true; } if (a[i-1] - a[i] > k){ res+=a[i-1] - (a[i] + k); a[i] = a[i-1] - k; changed = true; } } } cout<<res<<endl; } |
English