結果

問題 No.862 XORでX
ユーザー ks2mks2m
提出日時 2019-08-09 23:54:01
言語 Java21
(openjdk 21)
結果
AC  
実行時間 510 ms / 2,000 ms
コード長 1,791 bytes
コンパイル時間 2,202 ms
コンパイル使用メモリ 74,248 KB
実行使用メモリ 62,764 KB
最終ジャッジ日時 2023-09-26 22:13:32
合計ジャッジ時間 13,738 ms
ジャッジサーバーID
(参考情報)
judge15 / judge14
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 42 ms
49,244 KB
testcase_01 AC 42 ms
49,256 KB
testcase_02 AC 41 ms
49,024 KB
testcase_03 AC 41 ms
49,080 KB
testcase_04 AC 42 ms
49,296 KB
testcase_05 AC 41 ms
49,440 KB
testcase_06 AC 42 ms
49,300 KB
testcase_07 AC 42 ms
49,284 KB
testcase_08 AC 175 ms
54,200 KB
testcase_09 AC 169 ms
54,080 KB
testcase_10 AC 171 ms
53,780 KB
testcase_11 AC 171 ms
54,168 KB
testcase_12 AC 42 ms
49,528 KB
testcase_13 AC 42 ms
49,284 KB
testcase_14 AC 44 ms
49,196 KB
testcase_15 AC 43 ms
49,092 KB
testcase_16 AC 403 ms
62,416 KB
testcase_17 AC 398 ms
62,112 KB
testcase_18 AC 411 ms
62,400 KB
testcase_19 AC 407 ms
62,764 KB
testcase_20 AC 492 ms
62,276 KB
testcase_21 AC 481 ms
62,344 KB
testcase_22 AC 486 ms
62,028 KB
testcase_23 AC 494 ms
62,344 KB
testcase_24 AC 481 ms
62,172 KB
testcase_25 AC 492 ms
62,288 KB
testcase_26 AC 482 ms
62,160 KB
testcase_27 AC 510 ms
62,376 KB
testcase_28 AC 480 ms
62,448 KB
testcase_29 AC 488 ms
62,748 KB
testcase_30 AC 488 ms
61,828 KB
testcase_31 AC 500 ms
62,616 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

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[] sa = br.readLine().split(" ");
		int n = Integer.parseInt(sa[0]);
		int x = Integer.parseInt(sa[1]);
		br.close();

		int n4 = n % 4;
		if (n4 == 0) n4 = 4;
		int x4 = x % 4;
		int l = x - x4;
		int r = x - x4 + 4;
		int start = 8;
		int end = n - n4 + 8;
		if (8 <= l && r <= end) start = 4;

		for (int i = start; i < end; i++) {
			if (l <= i && i < r) {
				continue;
			}
			System.out.println(i);
		}

		switch (n4) {
		case 1:
			System.out.println(x);
			break;
		case 2:
			if (x == 1) {
				System.out.println(2);
				System.out.println(3);
			} else {
				System.out.println(x % 2 == 0 ? x + 1 : x - 1);
				System.out.println(1);
			}
			break;
		case 3:
			if (x == 1) {
				System.out.println(3);
				System.out.println(5);
				System.out.println(7);
			} else if (x < 4) {
				System.out.println(x % 2 == 0 ? x + 1 : x - 1);
				System.out.println(6);
				System.out.println(7);
			} else {
				System.out.println(x % 2 == 0 ? x + 1 : x - 1);
				System.out.println(2);
				System.out.println(3);
			}
			break;
		default:
			if (x == 1) {
				System.out.println(1);
				System.out.println(2);
				System.out.println(4);
				System.out.println(6);
			} else if (x < 4) {
				System.out.println(x);
				System.out.println(1);
				System.out.println(4);
				System.out.println(5);
			} else {
				System.out.println(x);
				System.out.println(1);
				if (x4 < 2) {
					System.out.println(x - x4 + 2);
					System.out.println(x - x4 + 3);
				} else {
					System.out.println(x - x4 + 0);
					System.out.println(x - x4 + 1);
				}
			}
		}
	}
}
0