結果

問題 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
権限があれば一括ダウンロードができます

ソースコード

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

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