//Yukicoder //Q198 candy box // //二次元可変配列 //vector > mass; //vector > memo; //vector memo; //#include "stdafx.h" #include #include #include //list #include //queue #include //連想コンテナ(要素が自動でソートされる)、要素1つ(Key)、keyの重複ない、O(logN) #include //連想コンテナ(要素が自動でソートされる)、要素2つ(Key,data)、keyの重複ない、dataは重複あり、O(logN) #include //hash、O(1) #include //hash、O(1) #include #include #include #include #include //#include using namespace std; #define FOR(x,to) for(x=0;x(b)?(a):(b)) #define FMIN(a,b) ((a)<(b)?(a):(b)) #define FCEIL(a,b) ((a)+(b)-1)/(b) typedef unsigned long long ULL; typedef signed long long SLL; queue _queue; vector > memo2; vector memo1; vector c; vector K; vector dp; SLL N, D, H ,A, B; SLL C[15]; SLL solve(SLL target) { SLL ans = 0; //cout << "_target=" << target << endl; // キャンディーの数の操作回数を求める // 1個づつしか操作できないので差分が操作回数になる for (int i = 0; i < N; i++) { //cout << c[i] << ": diff=" << abs(c[i] - target) << endl; ans += abs(C[i] - target); } //cout << "_ans=" << ans << endl; return ans; } int main() { cin >> B; cin >> N; SLL minimum = LLONG_MAX; SLL total = 0; for (int i=0;i> C[i]; if (C[i] < minimum) minimum = C[i]; total += C[i]; } // 答えは low と high の間にある SLL low = minimum; //各箱の中に最初から入っているキャンデーの数のなかで最も少ない数 SLL high = (total + B) / N; //各箱に入れることが出来る最大数 //箱の中のキャンディーの数 SLL c1, c2; while (abs(high-low) > 2) { //cout << "low=" << low << ",high=" << high << endl; c1 = (high + 2 * low) / 3; //箱の中のキャンディーの数の候補1 c2 = (high * 2 + low) / 3; //箱の中のキャンディーの数の候補2 // それに必要な操作回数の比較 if (solve(c1) < solve(c2)) high = c2; else low = c1; } SLL ans = LLONG_MAX; //cout << "***low=" << low << ",high=" << high << endl; //最終的に絞り込んだ範囲の中での最小値が答えになる for (SLL i=low;i<=high;i++) { SLL tmp = solve(i); if (tmp < ans) { ans = tmp; //cout << "*ans=" << ans << endl; } } cout << ans << endl; //getchar(); return 0; //end }