結果

問題 No.145 yukiover
ユーザー 37zigen37zigen
提出日時 2018-06-14 19:21:20
言語 Java
(openjdk 23)
結果
AC  
実行時間 235 ms / 5,000 ms
コード長 1,846 bytes
コンパイル時間 2,168 ms
コンパイル使用メモリ 79,008 KB
実行使用メモリ 56,776 KB
最終ジャッジ日時 2024-06-30 14:27:40
合計ジャッジ時間 7,405 ms
ジャッジサーバーID
(参考情報)
judge5 / judge2
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 127 ms
53,992 KB
testcase_01 AC 133 ms
54,244 KB
testcase_02 AC 131 ms
53,928 KB
testcase_03 AC 129 ms
53,944 KB
testcase_04 AC 130 ms
54,020 KB
testcase_05 AC 115 ms
53,880 KB
testcase_06 AC 131 ms
53,956 KB
testcase_07 AC 131 ms
54,432 KB
testcase_08 AC 130 ms
54,088 KB
testcase_09 AC 132 ms
54,316 KB
testcase_10 AC 132 ms
54,280 KB
testcase_11 AC 210 ms
55,980 KB
testcase_12 AC 226 ms
56,320 KB
testcase_13 AC 220 ms
55,932 KB
testcase_14 AC 224 ms
56,048 KB
testcase_15 AC 235 ms
55,160 KB
testcase_16 AC 231 ms
55,232 KB
testcase_17 AC 220 ms
56,084 KB
testcase_18 AC 230 ms
54,940 KB
testcase_19 AC 229 ms
55,144 KB
testcase_20 AC 230 ms
56,252 KB
testcase_21 AC 226 ms
56,636 KB
testcase_22 AC 220 ms
56,776 KB
testcase_23 AC 226 ms
56,292 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Comparator;
import java.util.Scanner;

public class Main {
	public static void main(String[] args) {
		new Main().run();
	}

	String yuki = "yuki";

	void run() {
		Scanner sc = new Scanner(System.in);
		int N = sc.nextInt();
		String str = sc.next();
		int abcdefgh = 0, i = 0, j = 0, k = 0, lmnopqrst = 0, u = 0, vwx = 0, y = 0, z = 0;

		for (int t = 0; t < str.length(); ++t) {
			if (str.charAt(t) - 'i' < 0)
				++abcdefgh;
			else if (str.charAt(t) == 'i') {
				++i;
			} else if (str.charAt(t) - 'j' == 0)
				++j;
			else if (str.charAt(t) - 'k' == 0)
				++k;
			else if (str.charAt(t) - 'l' >= 0 && str.charAt(t) - 't' <= 0)
				++lmnopqrst;
			else if (str.charAt(t) - 'u' == 0)
				++u;
			else if (str.charAt(t) - 'v' >= 0 && str.charAt(t) - 'x' <= 0)
				++vwx;
			else if (str.charAt(t) == 'y')
				++y;
			else if (str.charAt(t) == 'z')
				++z;
			else {
				tr(str.charAt(t));
				throw new AssertionError();
			}
		}
		int ans = 0;
		while (y > 0 && u > 0 && k > 0 && i > 0 && abcdefgh > 0) {
			++ans;
			--y;
			--u;
			--k;
			--i;
			--abcdefgh;
		}
		while (y > 0 && u > 0 && k > 0 && i >= 2) {
			++ans;
			--y;
			--u;
			--k;
			i -= 2;
			--abcdefgh;
		}
		while (y > 0 && u > 0 && k > 0 && j > 0) {
			++ans;
			--y;
			--u;
			--k;
			--i;
			--j;
		}
		while (y > 0 && u > 0 && k >= 2) {
			++ans;
			--y;
			--u;
			k -= 2;
		}
		while (y > 0 && u > 0 && lmnopqrst > 0) {
			++ans;
			--y;
			--u;
			--lmnopqrst;
		}
		while (y > 0 && u >= 2) {
			++ans;
			--y;
			u -= 2;
		}
		while (y > 0 && vwx > 0) {
			++ans;
			--y;
			--vwx;
		}
		while (y >= 2) {
			++ans;
			y -= 2;
		}
		while (z > 0) {
			++ans;
			--z;
		}
		System.out.println(ans);
	}

	void tr(Object... objects) {
		System.out.println(Arrays.deepToString(objects));
	}
}
0