Logo
(追記) (追記ここまで)

17407번 - 괄호 문자열과 쿼리

시간 제한메모리 제한제출정답맞힌 사람정답 비율
0.5 초 512 MB77835728944.946%

문제

괄호 문자열은 '('와 ')'로 이루어진 문자열이고, 올바른 괄호 문자열은 다음과 같이 정의된다.

  1. 빈 문자열은 올바른 괄호 문자열이다.
  2. S가 올바른 괄호 문자열일 때, (S)도 올바른 괄호 문자열이다.
  3. S와 T가 올바른 괄호 문자열이라면, ST도 올바른 괄호 문자열이다.
  4. 모든 올바른 괄호 문자열은 위의 3개 규칙으로만 만들 수 있다.

'('와 ')'로 이루어진 괄호 문자열 S = s1s2...sN과 M개의 쿼리가 주어진다. 쿼리는 정수 하나 index로 이루어져 있고, 쿼리가 의미하는 것은 다음과 같다.

  • S의 i번째 문자가 '('면 ')'로, ')'면 '('로 변경한다.

쿼리의 수행은 누적되며, i번째 쿼리는 i-1번째 쿼리가 수행된 결과에 수행되어야 한다. 각 쿼리를 수행한 결과가 올바른 괄호 문자열이었던 횟수를 모두 세어보자.

입력

첫째 줄에 문자열 S가 주어진다. 둘째 줄에 쿼리의 개수 M이 주어진다. 셋째 줄부터 M개의 줄에 쿼리 index가 한 줄에 하나씩 주어진다.

출력

첫째 줄에 쿼리를 수행한 결과가 올바른 괄호 문자열이었던 횟수를 출력한다.

제한

  • 1 ≤ |S| ≤ 100,000
  • 1 ≤ M ≤ 100,000
  • 1 ≤ index ≤ |S|

예제 입력 1

()()()()
8
2
7
4
5
3
7
1
2

예제 출력 1

3

힌트

S = "()()()()"에 예제 1의 쿼리를 수행한 결과는 다음과 같다.

  • ((()()()
  • ((()()))
  • ((((()))
  • (((())))
  • (()())))
  • (()())()
  • )()())()
  • )))())()

출처

(追記) (追記ここまで)

출처

대학교 대회

  • 사업자 등록 번호: 541-88-00682
  • 대표자명: 최백준
  • 주소: 서울시 서초구 서초대로74길 29 서초파라곤 412호
  • 전화번호: 02-521-0487 (이메일로 연락 주세요)
  • 이메일: contacts@startlink.io
  • 통신판매신고번호: 제 2017-서울서초-2193 호

AltStyle によって変換されたページ (->オリジナル) /