結果
| 問題 |
No.22 括弧の対応
|
| コンテスト | |
| ユーザー |
_Clay____
|
| 提出日時 | 2018-10-15 22:17:35 |
| 言語 | Rust (1.83.0 + proconio) |
| 結果 |
AC
|
| 実行時間 | 1 ms / 5,000 ms |
| コード長 | 696 bytes |
| コンパイル時間 | 13,809 ms |
| コンパイル使用メモリ | 376,376 KB |
| 実行使用メモリ | 5,376 KB |
| 最終ジャッジ日時 | 2024-07-20 07:36:07 |
| 合計ジャッジ時間 | 12,838 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 19 |
ソースコード
use std::io::*;
fn main() {
let s = stdin();
let mut handle = s.lock();
let mut buf = String::new();
handle.read_line(&mut buf).ok();
let l: Vec<u16> = buf
.trim()
.split_whitespace()
.map(|e| e.parse().ok().unwrap())
.collect();
let k = l[1] - 1;
let l = b'(';
buf.clear();
handle.read_line(&mut buf).ok();
let s = buf.trim().as_bytes().to_vec();
let mut b = Vec::new();
for i in 0..s.len() {
if s[i] == l {
b.push(i);
} else {
let pop = b.pop().unwrap() as u16;
if k == pop {
println!("{}", i + 1);
return;
} else if k == i as u16 {
println!("{}", pop + 1);
return;
}
}
}
}
_Clay____