結果

問題 No.3526 Anti SKG
コンテスト
ユーザー ks2m
提出日時 2026-05-04 21:29:48
言語 Java
(openjdk 25.0.2)
コンパイル:
javac -encoding UTF8 _filename_
実行:
java -ea -Xmx700m -Xss256M -DONLINE_JUDGE=true _class_
結果
AC  
実行時間 80 ms / 2,000 ms
コード長 1,297 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 2,604 ms
コンパイル使用メモリ 81,756 KB
実行使用メモリ 42,444 KB
最終ジャッジ日時 2026-05-04 21:29:58
合計ジャッジ時間 6,693 ms
ジャッジサーバーID
(参考情報)
judge3_0 / judge2_1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 30
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

import java.io.BufferedReader;
import java.io.InputStreamReader;

public class Main {
	public static void main(String[] args) throws Exception {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		String t = br.readLine();
		br.close();

		if (t.indexOf("SKG") != -1) {
			System.out.println("No");
			return;
		}

		char[] s = t.toCharArray();
		for (int i = 0; i < s.length; i++) {
			if (s[i] == '.') {
				s[i] = 'G';
				boolean ok = true;
				for (int j = Math.max(i - 2, 0); j <= Math.min(i, s.length - 3); j++) {
					if (s[j] == 'S' && s[j + 1] == 'K' && s[j + 2] == 'G') {
						ok = false;
						break;
					}
				}
				if (ok) {
					continue;
				}

				s[i] = 'K';
				ok = true;
				for (int j = Math.max(i - 2, 0); j <= Math.min(i, s.length - 3); j++) {
					if (s[j] == 'S' && s[j + 1] == 'K' && s[j + 2] == 'G') {
						ok = false;
						break;
					}
				}
				if (ok) {
					continue;
				}

				s[i] = 'S';
				ok = true;
				for (int j = Math.max(i - 2, 0); j <= Math.min(i, s.length - 3); j++) {
					if (s[j] == 'S' && s[j + 1] == 'K' && s[j + 2] == 'G') {
						ok = false;
						break;
					}
				}
				if (ok) {
					continue;
				}

				System.out.println("No");
				return;
			}
		}
		System.out.println("Yes");
		System.out.println(s);
	}
}
0