結果
問題 | No.91 赤、緑、青の石 |
ユーザー |
|
提出日時 | 2016-02-10 19:39:40 |
言語 | C++11 (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 2 ms / 5,000 ms |
コード長 | 1,035 bytes |
コンパイル時間 | 1,401 ms |
コンパイル使用メモリ | 161,352 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-06-24 06:54:56 |
合計ジャッジ時間 | 2,267 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 28 |
ソースコード
#include <bits/stdc++.h>using namespace std;typedef long long ll;#define rep(i,n) for(i=0;i<n;++i)#define each(itr,c) for(__typeof(c.begin()) itr=c.begin(); itr!=c.end(); itr++)#define mp make_pair#define pb push_back#define fi first#define sc secondint main(int argc, char const *argv[]) {int i;int a[3];rep(i,3) cin >>a[i];sort(a,a+3,greater<int>());int left=0,right=10000010;int mid;while(left<right){mid=(left+right)/2;bool end=(right-left<=1);if(end) mid=right;//mid個作れるか判定bool valid=true;if(a[0]<mid) valid=false;else{//とりあえず変える数int ch=(a[0]-mid)/2;if(a[1]>=mid){//足りてたら更に変えるch+=(a[1]-mid)/2;}else{ch-=(mid-a[1]);}if(a[2]+ch<mid){//足りないvalid=false;}}if(end){if(!valid) mid=left;break;}if(valid) left=mid;else right=mid;}std::cout << mid << std::endl;return 0;}