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

28709번 - 와일드카드 괄호 문자열 다국어

시간 제한메모리 제한제출정답맞힌 사람정답 비율
1 초 1024 MB116425922925.644%

문제

(’, ‘)’로 이루어진 문자열이 올바른 괄호 문자열이라는 것은 다음을 의미합니다.

  • $S$가 빈 문자열이면, $S$는 올바른 괄호 문자열입니다.
  • $S$가 올바른 괄호 문자열이면, $S$의 앞뒤에 각각 ‘(’와 ‘)’를 붙여 만든 문자열 “($S$)” 는 올바른 괄호 문자열입니다.
  • $S$와 $T$가 올바른 괄호 문자열이면, $S$와 $T$를 붙여 만든 문자열 “$ST$”는 올바른 괄호 문자열입니다.
  • 위 세 규칙을 통해 만들 수 없는 문자열은 올바른 괄호 문자열이 아닙니다.

예를 들어, “(())()”, “()()”은 올바른 괄호 문자열이고 “)(”, “())(”는 올바른 괄호문자열이 아닙니다.

문자열 $S$가 주어집니다. $S$는 ‘(’, ‘)’, ‘?’, ‘*’로 이루어진 문자열입니다. ‘?’ 문자를 ‘(’이나 ‘)’로, ‘*’ 문자를 ‘(’와 ‘)’로 이루어진 길이가 0ドル$ 이상인 원하는 문자열로 대체하여 $S$를 올바른 괄호 문자열로 만들 수 있나요?

입력

첫 줄에 테스트케이스의 수 $T$가 주어집니다. $(1 \le T \le 10,000円)$

각 테스트케이스의 첫 줄에는 ‘(’, ‘)’, ‘?’, ‘*’로 이루어진 길이가 1ドル$ 이상 500ドル,000円$ 이하인 문자열 $S$가 주어집니다.

입력에서 주어진 문자열 $S$의 길이 합은 500ドル,000円$을 넘지 않습니다.

출력

각 테스트케이스마다 한 줄에 하나씩, ‘?’ 문자를 ‘(’이나 ‘)’로, ‘*’ 문자를 ‘(’, ‘)’로 이루어진 길이가 0ドル$ 이상인 원하는 문자열로 대체하여 $S$를 올바른 괄호 문자열로 만들 수 있다면 “YES”, 불가능하면 “NO”를 출력하세요.

제한

예제 입력 1

4
()??))
())*(())
*)))(((*
?()(?*))(()?

예제 출력 1

YES
NO
YES
YES
  • 첫째 테스트 케이스는 두 개의 ‘?’를 ‘(’로 대체해서 $S$를 올바른 괄호 문자열 “()(())”로 만들 수 있습니다.
  • 두 번째 테스트 케이스는 ‘*’을 어떻게 대체해도 $S$를 올바른 괄호 문자열로 만들 수 없습니다.
  • 세 번째 테스트 케이스는 두 개의 ‘*’을 각각 “(((” 와 “)))”로 대체해서 $S$를 올바른 괄호 문자열 “((()))((()))”로 만들 수 있습니다.
  • 네 번째 테스트 케이스는 ‘?’, ‘?’, ‘*’, ‘?’를 차례로 ‘(’, ‘)’, “(”, ‘)’로 대체해서 $S$를 올바른 괄호 문자열 “(()()())(())”로 만들 수 있습니다.

노트

[{"problem_id":"28709","problem_lang":"0","title":"\uc640\uc77c\ub4dc\uce74\ub4dc \uad04\ud638 \ubb38\uc790\uc5f4","description":"<p>&lsquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>&rsquo;, &lsquo;<span style=\"color:#e74c3c;\"><code>)<\/code><\/span>&rsquo;\ub85c \uc774\ub8e8\uc5b4\uc9c4 \ubb38\uc790\uc5f4\uc774 \uc62c\ubc14\ub978 \uad04\ud638 \ubb38\uc790\uc5f4\uc774\ub77c\ub294 \uac83\uc740 \ub2e4\uc74c\uc744 \uc758\ubbf8\ud569\ub2c8\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>$S$\uac00 \ube48 \ubb38\uc790\uc5f4\uc774\uba74, $S$\ub294 \uc62c\ubc14\ub978 \uad04\ud638 \ubb38\uc790\uc5f4\uc785\ub2c8\ub2e4.<\/li>\r\n\t<li>$S$\uac00 \uc62c\ubc14\ub978 \uad04\ud638 \ubb38\uc790\uc5f4\uc774\uba74, $S$\uc758 \uc55e\ub4a4\uc5d0 \uac01\uac01 &lsquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>&rsquo;\uc640 &lsquo;<span style=\"color:#e74c3c;\"><code>)<\/code><\/span>&rsquo;\ub97c \ubd99\uc5ec \ub9cc\ub4e0 \ubb38\uc790\uc5f4 &ldquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>$S$<span style=\"color:#e74c3c;\"><code>)<\/code><\/span>&rdquo; \ub294 \uc62c\ubc14\ub978 \uad04\ud638 \ubb38\uc790\uc5f4\uc785\ub2c8\ub2e4.<\/li>\r\n\t<li>$S$\uc640 $T$\uac00 \uc62c\ubc14\ub978 \uad04\ud638 \ubb38\uc790\uc5f4\uc774\uba74, $S$\uc640 $T$\ub97c \ubd99\uc5ec \ub9cc\ub4e0 \ubb38\uc790\uc5f4 &ldquo;$ST$&rdquo;\ub294 \uc62c\ubc14\ub978 \uad04\ud638 \ubb38\uc790\uc5f4\uc785\ub2c8\ub2e4.<\/li>\r\n\t<li>\uc704 \uc138 \uaddc\uce59\uc744 \ud1b5\ud574 \ub9cc\ub4e4 \uc218 \uc5c6\ub294 \ubb38\uc790\uc5f4\uc740 \uc62c\ubc14\ub978 \uad04\ud638 \ubb38\uc790\uc5f4\uc774 \uc544\ub2d9\ub2c8\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\uc608\ub97c \ub4e4\uc5b4, &ldquo;<span style=\"color:#e74c3c;\"><code>(())()<\/code><\/span>&rdquo;, &ldquo;<span style=\"color:#e74c3c;\"><code>()()<\/code><\/span>&rdquo;\uc740 \uc62c\ubc14\ub978 \uad04\ud638 \ubb38\uc790\uc5f4\uc774\uace0 &ldquo;<span style=\"color:#e74c3c;\"><code>)(<\/code><\/span>&rdquo;, &ldquo;<span style=\"color:#e74c3c;\"><code>())(<\/code><\/span>&rdquo;\ub294 \uc62c\ubc14\ub978 \uad04\ud638\ubb38\uc790\uc5f4\uc774 \uc544\ub2d9\ub2c8\ub2e4.<\/p>\r\n\r\n<p>\ubb38\uc790\uc5f4 $S$\uac00 \uc8fc\uc5b4\uc9d1\ub2c8\ub2e4. $S$\ub294 &lsquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>&rsquo;, &lsquo;<span style=\"color:#e74c3c;\"><code>)<\/code><\/span>&rsquo;, &lsquo;<span style=\"color:#e74c3c;\"><code>?<\/code><\/span>&rsquo;, &lsquo;<span style=\"color:#e74c3c;\"><code>*<\/code><\/span>&rsquo;\ub85c \uc774\ub8e8\uc5b4\uc9c4 \ubb38\uc790\uc5f4\uc785\ub2c8\ub2e4. &lsquo;<span style=\"color:#e74c3c;\"><code>?<\/code><\/span>&rsquo; \ubb38\uc790\ub97c &lsquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>&rsquo;\uc774\ub098 &lsquo;<span style=\"color:#e74c3c;\"><code>)<\/code><\/span>&rsquo;\ub85c, &lsquo;<span style=\"color:#e74c3c;\"><code>*<\/code><\/span>&rsquo; \ubb38\uc790\ub97c &lsquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>&rsquo;\uc640 &lsquo;<span style=\"color:#e74c3c;\"><code>)<\/code><\/span>&rsquo;\ub85c \uc774\ub8e8\uc5b4\uc9c4 \uae38\uc774\uac00 $0$ \uc774\uc0c1\uc778 \uc6d0\ud558\ub294 \ubb38\uc790\uc5f4\ub85c \ub300\uccb4\ud558\uc5ec $S$\ub97c \uc62c\ubc14\ub978 \uad04\ud638 \ubb38\uc790\uc5f4\ub85c \ub9cc\ub4e4 \uc218 \uc788\ub098\uc694?<\/p>\r\n","input":"<p>\uccab \uc904\uc5d0 \ud14c\uc2a4\ud2b8\ucf00\uc774\uc2a4\uc758 \uc218 $T$\uac00 \uc8fc\uc5b4\uc9d1\ub2c8\ub2e4. $(1 \\le T \\le 10\\,000)$<\/p>\r\n\r\n<p>\uac01 \ud14c\uc2a4\ud2b8\ucf00\uc774\uc2a4\uc758 \uccab \uc904\uc5d0\ub294 &lsquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>&rsquo;, &lsquo;<span style=\"color:#e74c3c;\"><code>)<\/code><\/span>&rsquo;, &lsquo;<span style=\"color:#e74c3c;\"><code>?<\/code><\/span>&rsquo;, &lsquo;<span style=\"color:#e74c3c;\"><code>*<\/code><\/span>&rsquo;\ub85c \uc774\ub8e8\uc5b4\uc9c4 \uae38\uc774\uac00 $1$ \uc774\uc0c1 $500\\,000$ \uc774\ud558\uc778 \ubb38\uc790\uc5f4 $S$\uac00 \uc8fc\uc5b4\uc9d1\ub2c8\ub2e4.<\/p>\r\n\r\n<p>\uc785\ub825\uc5d0\uc11c \uc8fc\uc5b4\uc9c4 \ubb38\uc790\uc5f4 $S$\uc758 \uae38\uc774 \ud569\uc740 $500\\,000$\uc744 \ub118\uc9c0 \uc54a\uc2b5\ub2c8\ub2e4.<\/p>\r\n","output":"<p>\uac01 \ud14c\uc2a4\ud2b8\ucf00\uc774\uc2a4\ub9c8\ub2e4 \ud55c \uc904\uc5d0 \ud558\ub098\uc529, &lsquo;<span style=\"color:#e74c3c;\"><code>?<\/code><\/span>&rsquo; \ubb38\uc790\ub97c &lsquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>&rsquo;\uc774\ub098 &lsquo;<span style=\"color:#e74c3c;\"><code>)<\/code><\/span>&rsquo;\ub85c, &lsquo;<span style=\"color:#e74c3c;\"><code>*<\/code><\/span>&rsquo; \ubb38\uc790\ub97c &lsquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>&rsquo;, &lsquo;<span style=\"color:#e74c3c;\"><code>)<\/code><\/span>&rsquo;\ub85c \uc774\ub8e8\uc5b4\uc9c4 \uae38\uc774\uac00 $0$ \uc774\uc0c1\uc778 \uc6d0\ud558\ub294 \ubb38\uc790\uc5f4\ub85c \ub300\uccb4\ud558\uc5ec $S$\ub97c \uc62c\ubc14\ub978 \uad04\ud638 \ubb38\uc790\uc5f4\ub85c \ub9cc\ub4e4 \uc218 \uc788\ub2e4\uba74 &ldquo;<span style=\"color:#e74c3c;\"><code>YES<\/code><\/span>&rdquo;, \ubd88\uac00\ub2a5\ud558\uba74 &ldquo;<span style=\"color:#e74c3c;\"><code>NO<\/code><\/span>&rdquo;\ub97c \ucd9c\ub825\ud558\uc138\uc694.<\/p>\r\n","hint":"","original":"1","html_title":"0","problem_lang_tcode":"Korean","sample_explain_1":"<ul>\r\n\t<li>\uccab\uc9f8 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\ub294 \ub450 \uac1c\uc758 &lsquo;<span style=\"color:#e74c3c;\"><code>?<\/code><\/span>&rsquo;\ub97c &lsquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>&rsquo;\ub85c \ub300\uccb4\ud574\uc11c $S$\ub97c \uc62c\ubc14\ub978 \uad04\ud638 \ubb38\uc790\uc5f4 &ldquo;<span style=\"color:#e74c3c;\"><code>()(())<\/code><\/span>&rdquo;\ub85c \ub9cc\ub4e4 \uc218 \uc788\uc2b5\ub2c8\ub2e4.<\/li>\r\n\t<li>\ub450 \ubc88\uc9f8 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\ub294 &lsquo;<span style=\"color:#e74c3c;\"><code>*<\/code><\/span>&rsquo;\uc744 \uc5b4\ub5bb\uac8c \ub300\uccb4\ud574\ub3c4 $S$\ub97c \uc62c\ubc14\ub978 \uad04\ud638 \ubb38\uc790\uc5f4\ub85c \ub9cc\ub4e4 \uc218 \uc5c6\uc2b5\ub2c8\ub2e4.<\/li>\r\n\t<li>\uc138 \ubc88\uc9f8 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\ub294 \ub450 \uac1c\uc758 &lsquo;<span style=\"color:#e74c3c;\"><code>*<\/code><\/span>&rsquo;\uc744 \uac01\uac01 &ldquo;<span style=\"color:#e74c3c;\"><code>(((<\/code><\/span>&rdquo; \uc640 &ldquo;<span style=\"color:#e74c3c;\"><code>)))<\/code><\/span>&rdquo;\ub85c \ub300\uccb4\ud574\uc11c $S$\ub97c \uc62c\ubc14\ub978 \uad04\ud638 \ubb38\uc790\uc5f4 &ldquo;<span style=\"color:#e74c3c;\"><code>((()))((()))<\/code><\/span>&rdquo;\ub85c \ub9cc\ub4e4 \uc218 \uc788\uc2b5\ub2c8\ub2e4.<\/li>\r\n\t<li>\ub124 \ubc88\uc9f8 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\ub294 &lsquo;<span style=\"color:#e74c3c;\"><code>?<\/code><\/span>&rsquo;, &lsquo;<span style=\"color:#e74c3c;\"><code>?<\/code><\/span>&rsquo;, &lsquo;<span style=\"color:#e74c3c;\"><code>*<\/code><\/span>&rsquo;, &lsquo;<span style=\"color:#e74c3c;\"><code>?<\/code><\/span>&rsquo;\ub97c \ucc28\ub840\ub85c &lsquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>&rsquo;, &lsquo;<span style=\"color:#e74c3c;\"><code>)<\/code><\/span>&rsquo;, &ldquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>&rdquo;, &lsquo;<span style=\"color:#e74c3c;\"><code>)<\/code><\/span>&rsquo;\ub85c \ub300\uccb4\ud574\uc11c $S$\ub97c \uc62c\ubc14\ub978 \uad04\ud638 \ubb38\uc790\uc5f4 &ldquo;<span style=\"color:#e74c3c;\"><code>(()()())(())<\/code><\/span>&rdquo;\ub85c \ub9cc\ub4e4 \uc218 \uc788\uc2b5\ub2c8\ub2e4.<\/li>\r\n<\/ul>\r\n"},{"problem_id":"28709","problem_lang":"1","title":"Wildcard Parentheses String","description":"<p>A string consists of &lsquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>&rsquo; and &lsquo;<span style=\"color:#e74c3c;\"><code>)<\/code><\/span>&rsquo; is a <em>valid parentheses string <\/em>if it meets the following criteria:<\/p>\r\n\r\n<ul>\r\n\t<li>If $S$ is an empty string, $S$ is a valid parentheses string.<\/li>\r\n\t<li>If $S$ is a valid parentheses string, the string &ldquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>$S$<span style=\"color:#e74c3c;\"><code>)<\/code><\/span>&rdquo; created by attaching &lsquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>&rsquo; and &lsquo;<span style=\"color:#e74c3c;\"><code>)<\/code><\/span>&rsquo; respectively to the front and back of $S$ is a valid parentheses string.<\/li>\r\n\t<li>If $S$ and $T$ are valid parentheses strings, the string &ldquo;$ST$&rdquo; created by concatenating $S$ and $T$ is a valid parentheses string.<\/li>\r\n\t<li>A string that cannot be made by the above three rules is not a valid parentheses string.<\/li>\r\n<\/ul>\r\n\r\n<p>For example, &ldquo;<span style=\"color:#e74c3c;\"><code>(())()<\/code><\/span>&rdquo; and &ldquo;<span style=\"color:#e74c3c;\"><code>()()<\/code><\/span>&rdquo; are valid parentheses strings while &ldquo;<span style=\"color:#e74c3c;\"><code>)(<\/code><\/span>&rdquo; and &ldquo;<span style=\"color:#e74c3c;\"><code>())(<\/code><\/span>&rdquo; are not valid parentheses strings.<\/p>\r\n\r\n<p>You are given a string $S$ consisting of &lsquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>&rsquo;, &lsquo;<span style=\"color:#e74c3c;\"><code>)<\/code><\/span>&rsquo;, &lsquo;<span style=\"color:#e74c3c;\"><code>?<\/code><\/span>&rsquo;, and &lsquo;<span style=\"color:#e74c3c;\"><code>*<\/code><\/span>&rsquo;. Can you replace the &lsquo;<span style=\"color:#e74c3c;\"><code>?<\/code><\/span>&rsquo; characters with &lsquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>&rsquo; or &lsquo;<span style=\"color:#e74c3c;\"><code>)<\/code><\/span>&rsquo;, and the &lsquo;<span style=\"color:#e74c3c;\"><code>*<\/code><\/span>&rsquo; characters with a string of your choice of length $0$ or more consisting of &lsquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>&rsquo; and &lsquo;<span style=\"color:#e74c3c;\"><code>)<\/code><\/span>&rsquo; to make $S$ a valid parentheses string?<\/p>\r\n","input":"<p>The first line contains the number of test cases, $T$. $(1 \\le T \\le 10\\,000)$<\/p>\r\n\r\n<p>In each test case, the first line contains a string $S$ of length $1$ to $500\\,000$ consisting of &lsquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>&rsquo;, &lsquo;<span style=\"color:#e74c3c;\"><code>)<\/code><\/span>&rsquo;, &lsquo;<span style=\"color:#e74c3c;\"><code>?<\/code><\/span>&rsquo;, and &lsquo;<span style=\"color:#e74c3c;\"><code>*<\/code><\/span>&rsquo;.<\/p>\r\n\r\n<p>The sum of the lengths of the string $S$ given in the input does not exceed $500\\,000$.<\/p>\r\n","output":"<p>For each test case, print &ldquo;<span style=\"color:#e74c3c;\"><code>YES<\/code><\/span>&rdquo; if you can replace the &lsquo;<span style=\"color:#e74c3c;\"><code>?<\/code><\/span>&rsquo; characters with &lsquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>&rsquo; or &lsquo;<span style=\"color:#e74c3c;\"><code>)<\/code><\/span>&rsquo;, and the &lsquo;<span style=\"color:#e74c3c;\"><code>*<\/code><\/span>&rsquo; characters with a string of your choice of length $0$ or more consisting of &lsquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>&rsquo; and &lsquo;<span style=\"color:#e74c3c;\"><code>)<\/code><\/span>&rsquo; to make $S$ a valid parentheses string, &ldquo;<span style=\"color:#e74c3c;\"><code>NO<\/code><\/span>&rdquo; otherwise.<\/p>\r\n","hint":"","original":"0","html_title":"0","problem_lang_tcode":"English","sample_explain_1":"<ul>\r\n\t<li>For the first test case, you can replace two &lsquo;<span style=\"color:#e74c3c;\"><code>?<\/code><\/span>&rsquo;s with &lsquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>&rsquo; to make $S$ a valid parentheses string &ldquo;<span style=\"color:#e74c3c;\"><code>()(())<\/code><\/span>&rdquo;.<\/li>\r\n\t<li>For the second test case, no matter how you replace &lsquo;<span style=\"color:#e74c3c;\"><code>*<\/code><\/span>&rsquo;, you can&#39;t make $S$ a valid parentheses string.<\/li>\r\n\t<li>For the third test case, you can replace two &lsquo;<span style=\"color:#e74c3c;\"><code>*<\/code><\/span>&rsquo;s with &ldquo;<span style=\"color:#e74c3c;\"><code>(((<\/code><\/span>&rdquo; and &ldquo;<span style=\"color:#e74c3c;\"><code>)))<\/code><\/span>&rdquo; respectively to make $S$ a valid parentheses string &ldquo;<span style=\"color:#e74c3c;\"><code>((()))((()))<\/code><\/span>&rdquo;.<\/li>\r\n\t<li>For the fourth test case, you can replace the &lsquo;<span style=\"color:#e74c3c;\"><code>?<\/code><\/span>&rsquo;, &lsquo;<span style=\"color:#e74c3c;\"><code>?<\/code><\/span>&rsquo;, &lsquo;<span style=\"color:#e74c3c;\"><code>*<\/code><\/span>&rsquo;, and &lsquo;<span style=\"color:#e74c3c;\"><code>?<\/code><\/span>&rsquo; in order with &lsquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>&rsquo;, &lsquo;<span style=\"color:#e74c3c;\"><code>)<\/code><\/span>&rsquo;, &ldquo;<span style=\"color:#e74c3c;\"><code>(<\/code><\/span>&rdquo;, &lsquo;<span style=\"color:#e74c3c;\"><code>)<\/code><\/span>&rsquo; to make $S$ a valid parentheses string &ldquo;<span style=\"color:#e74c3c;\"><code>(()()())(())<\/code><\/span>&rdquo;.<\/li>\r\n<\/ul>\r\n"}]

출처

Contest > solved.ac > solved.ac Grand Arena #2 I번

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

출처

대학교 대회

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

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