結果
問題 | No.22 括弧の対応 |
ユーザー |
![]() |
提出日時 | 2015-05-21 20:02:34 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 2 ms / 5,000 ms |
コード長 | 878 bytes |
コンパイル時間 | 864 ms |
コンパイル使用メモリ | 61,916 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-07-20 07:01:03 |
合計ジャッジ時間 | 1,062 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 19 |
ソースコード
#include <iostream> #include <algorithm> #include <functional> #include <string> #include <limits.h> using namespace std; int main(){ int max,loc; string data; int lv[10000]; int freq[10000] = {0}; int cnt; int now; int ans; int target; cin >> max >> loc; cin >> data; loc --; //解法1(数値化して求める) now = 0; for(int i=0; i<max; i++){ if(data[i] == '('){ now ++; lv[i] = now; }else{ lv[i] = now; now --; } } //そのレベルの出現回数を求める cnt = 0; for(int i=0; i<max; i++){ if(lv[i] == lv[loc]){ cnt ++; freq[i] = cnt; } } //対応する位置を求める if(freq[loc] % 2 == 0){ //1,2,3... target = freq[loc] - 1; }else{ target = freq[loc] + 1; } //対応する位置番号を捜す。 for(int i=0; i<max; i++){ if(freq[i] == target){ cout << i+1 << endl; } } return 0; }