結果

問題 No.91 赤、緑、青の石
ユーザー imulan
提出日時 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
権限があれば一括ダウンロードができます

ソースコード

diff #
プレゼンテーションモードにする

#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;
}
הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
0