結果

問題 No.22 括弧の対応
コンテスト
ユーザー bigbear90560
提出日時 2015-09-17 18:21:01
言語 Java
(openjdk 25.0.2)
コンパイル:
javac -encoding UTF8 _filename_
実行:
java -ea -Xmx700m -Xss256M -DONLINE_JUDGE=true _class_
結果
AC  
実行時間 77 ms / 5,000 ms
コード長 933 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 2,424 ms
コンパイル使用メモリ 84,656 KB
実行使用メモリ 129,488 KB
最終ジャッジ日時 2026-04-02 21:44:50
合計ジャッジ時間 4,326 ms
ジャッジサーバーID
(参考情報)
judge3_0 / judge2_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 19
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

import java.util.Scanner;

public class No022_SupprotBrackets {

	public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int a = sc.nextInt();	// 文字数
        int b = sc.nextInt();	// 対象番号
        String s = sc.next();	// 文字列

        final String LB = "(";
        final String RB = ")";

        int cnt = 0;

        if (LB.equals(s.substring(b-1,b))) {
	        for (int i=b; i<a; i++) {
	        	if (LB.equals(s.substring(i, i+1))) cnt++;
	        	if (RB.equals(s.substring(i, i+1))) cnt--;
	        	if (cnt < 0) {
	        		System.out.println(i+1);
	        		break;
	        	}
	        }
        } else {
	        for (int i=b; i>0; i--) {
	        	if (LB.equals(s.substring(i-1, i))) cnt--;
	        	if (RB.equals(s.substring(i-1, i))) cnt++;
	        	if (cnt <= 0) {
	        		System.out.println(i);
	        		break;
	        	}
	        }
        }
	}

}
0