結果
| 問題 |
No.161 制限ジャンケン
|
| コンテスト | |
| ユーザー |
rodea
|
| 提出日時 | 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;
}
rodea