結果
| 問題 |
No.161 制限ジャンケン
|
| コンテスト | |
| ユーザー |
htensai
|
| 提出日時 | 2019-12-30 10:07:07 |
| 言語 | Java (openjdk 23) |
| 結果 |
AC
|
| 実行時間 | 137 ms / 5,000 ms |
| コード長 | 1,472 bytes |
| コンパイル時間 | 2,213 ms |
| コンパイル使用メモリ | 77,724 KB |
| 実行使用メモリ | 41,552 KB |
| 最終ジャッジ日時 | 2024-11-07 19:27:35 |
| 合計ジャッジ時間 | 5,736 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 16 |
ソースコード
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int g = sc.nextInt();
int c = sc.nextInt();
int p = sc.nextInt();
char[] arr = sc.next().toCharArray();
int gCount = 0;
int cCount = 0;
int pCount = 0;
for (char cc : arr) {
switch (cc) {
case 'G' :
gCount++;
break;
case 'C' :
cCount++;
break;
case 'P' :
pCount++;
break;
}
}
int point = 0;
if (gCount > p) {
point += p * 3;
gCount -= p;
p = 0;
} else {
point += gCount * 3;
p -= gCount;
gCount = 0;
}
if (cCount > g) {
point += g * 3;
cCount -= g;
g = 0;
} else {
point += cCount * 3;
g -= cCount;
cCount = 0;
}
if (pCount > c) {
point += c * 3;
pCount -= c;
c = 0;
} else {
point += pCount * 3;
c -= pCount;
pCount = 0;
}
point += Math.min(gCount, g);
point += Math.min(cCount, c);
point += Math.min(pCount, p);
System.out.println(point);
}
}
htensai