結果
問題 |
No.91 赤、緑、青の石
|
ユーザー |
|
提出日時 | 2018-06-16 11:28:30 |
言語 | C (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 1 ms / 5,000 ms |
コード長 | 462 bytes |
コンパイル時間 | 957 ms |
コンパイル使用メモリ | 28,160 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-06-24 07:14:45 |
合計ジャッジ時間 | 1,856 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 28 |
ソースコード
#include <stdio.h> #define MAX0(x) ((x) > 0 ? (x) : 0) int r, g, b; int p(int x){ int rr = r-x; int rg = g-x; int rb = b-x; int s = MAX0(rr)/2 + MAX0(rg)/2 + MAX0(rb)/2; int c = MAX0(-rr) + MAX0(-rg) + MAX0(-rb); return s >= c; } int main(){ int lb, ub; scanf("%d%d%d", &r, &g, &b); ub = 10000001; lb = 0; while(ub - lb > 1){ int m = (lb + ub) / 2; if(p(m)) lb = m; else ub = m; } printf("%d\n", lb); return 0; }