結果
| 問題 |
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 second
int 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;
}