結果
問題 | No.161 制限ジャンケン |
ユーザー |
![]() |
提出日時 | 2017-11-09 21:43:31 |
言語 | C (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 1 ms / 5,000 ms |
コード長 | 974 bytes |
コンパイル時間 | 427 ms |
コンパイル使用メモリ | 29,696 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2024-11-30 05:19:45 |
合計ジャッジ時間 | 917 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 16 |
ソースコード
#include<stdio.h>int main(void){int g, g1 = 0, c, c1 = 0, p, p1 = 0, ng = 0, ng1 = 0, ng2 = 0, nc = 0, nc1 = 0, nc2 = 0, np = 0, np1 = 0, np2 = 0, ans1, ans2;scanf("%d %d %d", &g, &c, &p);int n = g + c + p;char s[300];for (int i = 0; i < n+1; i++){s[i] = getchar();if (s[i] == 'G') ng++;else if (s[i] == 'C') nc++;else if (s[i] == 'P') np++;}if (g >= nc){g = g - nc;nc1 = nc;nc = 0;}else{nc = nc - g;nc2 = g;g = 0;}if (c >= np){c = c - np;np1 = np;np = 0;}else{np = np - c;np2 = c;c = 0;}if (p >= ng){p = p - ng;ng1 = ng;ng = 0;}else{ng = ng - p;ng2 = p;p = 0;}ans1 = (ng1 + nc1 + np1 + ng2 + nc2 + np2) * 3;if (g > 0 && ng > 0){g1 = g > ng ? ng : g;}if (c > 0 && nc > 0){c1 = c > nc ? nc : c;}if (p > 0 && np > 0){p1 = p > np ? np : p;}ans2 = g1 + c1 + p1;printf("%d\n", ans1 + ans2);return 0;}