結果
問題 |
No.161 制限ジャンケン
|
ユーザー |
|
提出日時 | 2015-09-20 23:36:12 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 2 ms / 5,000 ms |
コード長 | 1,097 bytes |
コンパイル時間 | 521 ms |
コンパイル使用メモリ | 59,036 KB |
実行使用メモリ | 5,248 KB |
最終ジャッジ日時 | 2024-11-30 04:46:06 |
合計ジャッジ時間 | 1,178 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 16 |
ソースコード
#include <iostream> using namespace std; #include <cstdio> #include <string.h> #include <stdlib.h> #include <math.h> #define FOR(i,a,b) for(int (i)=(a);i<(b);i++) typedef long long ll; typedef unsigned long long ull; typedef long double lb; /* ここからが本編 */ int main(void) { int i,j,k,l; int g1,c1,p1; int g2 = 0 ,c2 = 0 ,p2 = 0; int ans = 0; int max,min; char s[305]; cin >> g1 >> c1 >> p1; cin >> s; for(i=0;s[i];i++) { switch(s[i]) { case 'G' : g2++; break; case 'C' : c2++; break; case 'P' : p2++; break; } } min = g2; if(g2 > p1) min = p1; ans += min * 3; g2 -= min; p1 -= min; min = c2; if(c2 > g1) min = g1; ans += min * 3; c2 -= min; g1 -= min; min = p2; if(p2 > c1) min = c1; ans += min * 3; p2 -= min; c1 -= min; min = g2; if(g2 > g1) min = g1; ans += min; g2 -= min; g1 -= min; min = c2; if(c2 > c1) min = c1; ans += min; c2 -= min; c1 -= min; min = p2; if(p2 > p1) min = p1; ans += min; p2 -= min; p1 -= min; printf("%d\n",ans); return 0; }