結果
| 問題 | 
                            No.198 キャンディー・ボックス2
                             | 
                    
| コンテスト | |
| ユーザー | 
                             peroon
                         | 
                    
| 提出日時 | 2019-04-07 07:49:22 | 
| 言語 | C++14  (gcc 13.3.0 + boost 1.87.0)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 2 ms / 1,000 ms | 
| コード長 | 2,090 bytes | 
| コンパイル時間 | 1,013 ms | 
| コンパイル使用メモリ | 103,548 KB | 
| 実行使用メモリ | 5,376 KB | 
| 最終ジャッジ日時 | 2024-06-26 08:39:15 | 
| 合計ジャッジ時間 | 1,933 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge3 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 4 | 
| other | AC * 26 | 
ソースコード
#include<algorithm>
#include<complex>
#include<ctype.h>
#include<iomanip>
#include<iostream>
#include<fstream>
#include<map>
#include<math.h>
#include<numeric>
#include<queue>
#include<set>
#include<stack>
#include<stdio.h>
#include<string>
#include<string>
#include<vector>
using namespace std;
typedef long long ll;
#define FOR(i,a,b) for(ll i=(a);i<(b);++i)
#define ALL(v) (v).begin(), (v).end()
#define p(s) cout<<(s)<<endl
#define p2(s, t) cout << (s) << " " << (t) << endl
#define br() p("")
#define pn(s) cout << (#s) << " " << (s) << endl
#define p_yes() p("Yes")
#define p_no() p("No")
const ll mod = 1e9 + 7;
const ll inf = 1e18;
template < typename T >
void vprint(T &V){
	for(auto v : V){
    	cout << v << " ";
	}
	cout << endl;
}
ll B, N;
vector<ll> A;
ll how_many(ll target){
    ll stock = B;
    ll scarcity = 0;
    for(ll a : A){
        if(a>target){
            ll diff = a - target;
            stock += diff;
        }
        else if(a<target){
            ll diff = target - a;
            scarcity += diff;
        }
    }
    if(stock>=scarcity){
        // 集めた分
        ll collect = stock - B;
        // 埋める分
        // scarcity
        return collect + scarcity;
    }else{
        // 達成不可能
        return inf;
    }
}
int main(){
    cin.tie(0);
    ios::sync_with_stdio(false);
    // input
    cin >> B >> N;
    A.resize(N);
    FOR(i, 0, N){
        cin >> A.at(i);
    }
    sort(ALL(A));
    ll left = 0;
    ll right = *max_element(ALL(A));
    ll p0, p1;
    FOR(i, 0, 1000){
        double diff = right - left;
        p0 = left + diff * 1 / 3.0f;
        p1 = left + diff * 2 / 3.0f;
        ll n0 = how_many(p0);
        ll n1 = how_many(p1);
        if(n0==inf){
            right = p0;
        }
        else if(n1==inf){
            right = p1;
        }
        else if(n0<n1){
            right = p1;
        }
        else{
            left = p0;
        }
    }
    ll num = inf;
    FOR(i, left, right+1){
        ll n = how_many(i);
        num = min(num, n);
    }
    p(num);
    
    return 0;
}
            
            
            
        
            
peroon