結果

問題 No.2143 Only One Bracket
ユーザー 37zigen37zigen
提出日時 2022-12-02 21:49:56
言語 Java21
(openjdk 21)
結果
AC  
実行時間 138 ms / 2,000 ms
コード長 1,296 bytes
コンパイル時間 2,584 ms
コンパイル使用メモリ 88,232 KB
実行使用メモリ 41,484 KB
最終ジャッジ日時 2024-10-09 23:04:46
合計ジャッジ時間 4,461 ms
ジャッジサーバーID
(参考情報)
judge4 / judge1
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 133 ms
41,308 KB
testcase_01 AC 133 ms
41,112 KB
testcase_02 AC 135 ms
41,396 KB
testcase_03 AC 121 ms
39,980 KB
testcase_04 AC 138 ms
41,276 KB
testcase_05 AC 135 ms
41,184 KB
testcase_06 AC 135 ms
41,248 KB
testcase_07 AC 138 ms
41,484 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

import java.util.Arrays;
import java.util.Scanner;

public class Main {
	public static void main(String[] args) {
		new Main().run();
	}
	
	void run() {
		Scanner sc = new Scanner(System.in);
		int N = sc.nextInt();
		String[] s = new String[N];
		Arrays.fill(s, "");
		if (N % 2 == 0) {
			for (int i = 0; i < N / 2; ++i) {
				for (int j = 0; j < i; ++j) {
					s[i] = s[i] + ")";
				}
				for (int j = 0; j < i + 1; ++j) {
					s[i] = s[i] + "(";
				}
			}
			
			for (int i = 0; i < N / 2; ++i) {
				for (int j = 0; j < i + 1; ++j) {
					s[i + N / 2] = s[i + N / 2] + ")";
				}
				for (int j = 0; j < i; ++j) {
					s[i + N / 2] = s[i + N / 2] + "(";
				}
			}
		} else {
			for (int i = 0; i <= N / 2; ++i) {
				for (int j = 0; j < i; ++j) {
					s[i] = s[i] + ")";
				}
				for (int j = 0; j < i + 1; ++j) {
					s[i] = s[i] + "(";
				}
			}
			
			for (int i = 0; i < N / 2; ++i) {
				for (int j = 0; j < i + 1; ++j) {
					s[i + N / 2 + 1] = s[i + N / 2 + 1] + ")";
				}
				if (i == N / 2 - 1) s[i + N / 2 + 1] += ")";
				for (int j = 0; j < i; ++j) {
					s[i + N / 2 + 1] = s[i + N / 2 + 1] + "(";
				}
			}
		}
		
		for (int i = 0; i < N; ++i) {
			System.out.println(s[i]);
		}
	}
	
	void tr(Object...objects) {System.out.println(Arrays.deepToString(objects));}
	
	
}
0