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

31401번 - 집합 식 트랜스파일 스페셜 저지

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

문제

은하는 정해진 전체집합 안에서 집합을 다룰 수 있는 ‘아니야’라는 언어를 생각했습니다. ‘아니야’는 A부터 T까지 총 20ドル$개의 집합과, 다음과 같은 세 연산을 지원해 다양한 집합을 표현할 수 있습니다.

  • 교집합 연산자: 두 집합에 공통으로 속한 원소만을 추려 새로운 집합을 만듭니다. 기호는 &입니다($A$ 그리고 $B$에 속한 원소).
  • 합집합 연산자: 두 집합 중 어느 한 쪽 이상에 속한 원소만을 추려 새로운 집합을 만듭니다. 기호는 |입니다($A$ 또는 $B$에 속한 원소).
  • 여집합 연산자: 집합에 속하지 않은 원소만을 추려 새로운 집합을 만듭니다. 기호는 ~입니다($A$에 속하지 않은 원소).

연산을 서로 도합할 수 있습니다. 예를 들어, (A|B)&~C는 $A$와 $B$ 중 하나에 속한 원소 중 $C$에는 속하지 않은 원소들만을 추린 집합입니다. 이때, 연산자 우선순위는 ~가 가장 높고, 그 다음이 &, 마지막으로 | 순입니다. 앞서 보인 식처럼 괄호를 이용해 특정 연산자의 우선순위를 높일 수도 있습니다.

그런데, 자료조사 도중 주어진 집합에 원소가 있는지 판단하는, 엄청나게 빠르게 동작하는 구현체가 있는 ‘빼버려’라는 언어를 마주합니다. ‘빼버려’는 ‘아니야’와 다른 것은 모두 같고, 다음과 같은 차이점이 있습니다.

  • 여집합 연산자를 지원하지 않습니다.
  • 대신 차집합 연산자를 지원합니다. 이 연산자는 두 집합 중 왼쪽에만 속하는 원소만를 추려 새로운 집합을 만듭니다. 기호는 \입니다. 즉, A\B는 $A$에만 속하고 $B$에는 속하지 않는 원소들만이 속하는 집합입니다.
  • ‘빼버려’의 연산자 우선순위는 &가 가장 높고, 그 다음이 \, 마지막으로 | 순입니다.

은하는 ‘아니야’의 구현체를 만드는 데에 엄청나게 빠른 ‘빼버려’의 구현체를 이용할 생각을 했습니다. 그러려면 ‘아니야’의 식을 입력받아 빠른 시간 안에 다음과 같은 조건을 만족하는 ‘빼버려’의 식으로 바꾸어 주는 트랜스파일러가 필요합니다.

  • 당연히, ‘아니야’의 원래 식을 동등한 ‘빼버려’의 식으로 바꾼 결과는 원래 식과 동일한 집합을 표현해야 합니다.
  • ‘빼버려’에서의 맥락은 ‘아니야’에서의 맥락과 동일하므로, ‘아니야’의 원래 식을 동등한 ‘빼버려’의 식으로 바꾼 결과는 원래 식에 등장하는 집합만을 사용해야 합니다.
  • 아무리 ‘빼버려’가 빠른 구현체라도, 긴 식을 처리하는 데에는 오랜 시간이 걸릴 것입니다. 따라서 ‘아니야’의 원래 식을 동등한 ‘빼버려’의 식으로 바꾼 결과는 원래 식의 길이의 2ドル$배를 넘어서는 안 됩니다.

은하를 도와 이 트랜스파일러를 작성합시다!

입력

첫 줄에 올바른 ‘아니야’의 식이 주어집니다. 식은 공백 없이 주어지며, 2024ドル$자 이하입니다.

출력

첫 줄에, 주어진 ‘아니야’의 식을 지문에서 설명한 조건을 만족하는 ‘빼버려’의 식으로 바꿀 수 있다면 YES를, 그렇지 않다면 NO를 출력합니다.

첫 줄에 YES를 출력했다면, 둘째 줄에 집합 식을 출력합니다. 이 식은 공백을 포함하지 않는 올바른 ‘빼버려’의 식이어야 하며, 지문에서 설명한 조건을 만족해야 합니다.

제한

예제 입력 1

~A&B

예제 출력 1

YES
B\A

예제 입력 2

~A|B&A

예제 출력 2

NO

힌트

‘아니야’와 ‘빼버려’의 BNF(Backus-Naur Form)는 다음과 같습니다. 입력으로는 ‘아니야’의 Expression이 주어지고, 여러분은 ‘빼버려’의 Expression을 출력해야 합니다. [1]은 ‘아니야’에서만, [2]는 ‘빼버려’에서만 사용 가능합니다.

Expresssion =
| Set
| "~" Expression # [1]
| Expression "&" Expression
| Expression "\" Expression # [2]
| Expression "|" Expression
| "(" Expression ")"

Set =
| "A" | "B" | "C" | "D" | "E"
| "F" | "G" | "H" | "I" | "J"
| "K" | "L" | "M" | "N" | "O"
| "P" | "Q" | "R" | "S" | "T"

[{"problem_id":"31401","problem_lang":"0","title":"\uc9d1\ud569 \uc2dd \ud2b8\ub79c\uc2a4\ud30c\uc77c","description":"<p>\uc740\ud558\ub294 \uc815\ud574\uc9c4 \uc804\uccb4\uc9d1\ud569 \uc548\uc5d0\uc11c \uc9d1\ud569\uc744 \ub2e4\ub8f0 \uc218 \uc788\ub294 &lsquo;\uc544\ub2c8\uc57c&rsquo;\ub77c\ub294 \uc5b8\uc5b4\ub97c \uc0dd\uac01\ud588\uc2b5\ub2c8\ub2e4. &lsquo;\uc544\ub2c8\uc57c&rsquo;\ub294 <span style=\"color:#e74c3c;\"><code>A<\/code><\/span>\ubd80\ud130 <span style=\"color:#e74c3c;\"><code>T<\/code><\/span>\uae4c\uc9c0 \ucd1d $20$\uac1c\uc758 \uc9d1\ud569\uacfc, \ub2e4\uc74c\uacfc \uac19\uc740 \uc138 \uc5f0\uc0b0\uc744 \uc9c0\uc6d0\ud574 \ub2e4\uc591\ud55c \uc9d1\ud569\uc744 \ud45c\ud604\ud560 \uc218 \uc788\uc2b5\ub2c8\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>\uad50\uc9d1\ud569 \uc5f0\uc0b0\uc790: \ub450 \uc9d1\ud569\uc5d0 \uacf5\ud1b5\uc73c\ub85c \uc18d\ud55c \uc6d0\uc18c\ub9cc\uc744 \ucd94\ub824 \uc0c8\ub85c\uc6b4 \uc9d1\ud569\uc744 \ub9cc\ub4ed\ub2c8\ub2e4. \uae30\ud638\ub294 <span style=\"color:#e74c3c;\"><code>&amp;<\/code><\/span>\uc785\ub2c8\ub2e4($A$ <strong>\uadf8\ub9ac\uace0<\/strong> $B$\uc5d0 \uc18d\ud55c \uc6d0\uc18c).<\/li>\r\n\t<li>\ud569\uc9d1\ud569 \uc5f0\uc0b0\uc790: \ub450 \uc9d1\ud569 \uc911 \uc5b4\ub290 \ud55c \ucabd \uc774\uc0c1\uc5d0 \uc18d\ud55c \uc6d0\uc18c\ub9cc\uc744 \ucd94\ub824 \uc0c8\ub85c\uc6b4 \uc9d1\ud569\uc744 \ub9cc\ub4ed\ub2c8\ub2e4. \uae30\ud638\ub294 <span style=\"color:#e74c3c;\"><code>|<\/code><\/span>\uc785\ub2c8\ub2e4($A$ <strong>\ub610\ub294<\/strong> $B$\uc5d0 \uc18d\ud55c \uc6d0\uc18c).<\/li>\r\n\t<li>\uc5ec\uc9d1\ud569 \uc5f0\uc0b0\uc790: \uc9d1\ud569\uc5d0 \uc18d\ud558\uc9c0 \uc54a\uc740 \uc6d0\uc18c\ub9cc\uc744 \ucd94\ub824 \uc0c8\ub85c\uc6b4 \uc9d1\ud569\uc744 \ub9cc\ub4ed\ub2c8\ub2e4. \uae30\ud638\ub294 <span style=\"color:#e74c3c;\"><code>~<\/code><\/span>\uc785\ub2c8\ub2e4($A$\uc5d0 \uc18d\ud558\uc9c0 <strong>\uc54a\uc740<\/strong> \uc6d0\uc18c).<\/li>\r\n<\/ul>\r\n\r\n<p>\uc5f0\uc0b0\uc744 \uc11c\ub85c \ub3c4\ud569\ud560 \uc218 \uc788\uc2b5\ub2c8\ub2e4. \uc608\ub97c \ub4e4\uc5b4, <span style=\"color:#e74c3c;\"><code>(A|B)&amp;~C<\/code><\/span>\ub294 $A$\uc640 $B$ \uc911 \ud558\ub098\uc5d0 \uc18d\ud55c \uc6d0\uc18c \uc911 $C$\uc5d0\ub294 \uc18d\ud558\uc9c0 \uc54a\uc740 \uc6d0\uc18c\ub4e4\ub9cc\uc744 \ucd94\ub9b0 \uc9d1\ud569\uc785\ub2c8\ub2e4. \uc774\ub54c, \uc5f0\uc0b0\uc790 \uc6b0\uc120\uc21c\uc704\ub294 <span style=\"color:#e74c3c;\"><code>~<\/code><\/span>\uac00 \uac00\uc7a5 \ub192\uace0, \uadf8 \ub2e4\uc74c\uc774 <span style=\"color:#e74c3c;\"><code>&amp;<\/code><\/span>, \ub9c8\uc9c0\ub9c9\uc73c\ub85c <span style=\"color:#e74c3c;\"><code>|<\/code><\/span> \uc21c\uc785\ub2c8\ub2e4. \uc55e\uc11c \ubcf4\uc778 \uc2dd\ucc98\ub7fc \uad04\ud638\ub97c \uc774\uc6a9\ud574 \ud2b9\uc815 \uc5f0\uc0b0\uc790\uc758 \uc6b0\uc120\uc21c\uc704\ub97c \ub192\uc77c \uc218\ub3c4 \uc788\uc2b5\ub2c8\ub2e4.<\/p>\r\n\r\n<p>\uadf8\ub7f0\ub370, \uc790\ub8cc\uc870\uc0ac \ub3c4\uc911 \uc8fc\uc5b4\uc9c4 \uc9d1\ud569\uc5d0 \uc6d0\uc18c\uac00 \uc788\ub294\uc9c0 \ud310\ub2e8\ud558\ub294, \uc5c4\uccad\ub098\uac8c \ube60\ub974\uac8c \ub3d9\uc791\ud558\ub294 \uad6c\ud604\uccb4\uac00 \uc788\ub294 &lsquo;\ube7c\ubc84\ub824&rsquo;\ub77c\ub294 \uc5b8\uc5b4\ub97c \ub9c8\uc8fc\ud569\ub2c8\ub2e4. &lsquo;\ube7c\ubc84\ub824&rsquo;\ub294 &lsquo;\uc544\ub2c8\uc57c&rsquo;\uc640 \ub2e4\ub978 \uac83\uc740 \ubaa8\ub450 \uac19\uace0, \ub2e4\uc74c\uacfc \uac19\uc740 \ucc28\uc774\uc810\uc774 \uc788\uc2b5\ub2c8\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>\uc5ec\uc9d1\ud569 \uc5f0\uc0b0\uc790\ub97c <strong>\uc9c0\uc6d0\ud558\uc9c0 \uc54a\uc2b5\ub2c8\ub2e4<\/strong>.<\/li>\r\n\t<li>\ub300\uc2e0 <strong>\ucc28\uc9d1\ud569 \uc5f0\uc0b0\uc790<\/strong>\ub97c \uc9c0\uc6d0\ud569\ub2c8\ub2e4. \uc774 \uc5f0\uc0b0\uc790\ub294 \ub450 \uc9d1\ud569 \uc911 \uc67c\ucabd\uc5d0\ub9cc \uc18d\ud558\ub294 \uc6d0\uc18c\ub9cc\ub97c \ucd94\ub824 \uc0c8\ub85c\uc6b4 \uc9d1\ud569\uc744 \ub9cc\ub4ed\ub2c8\ub2e4. \uae30\ud638\ub294 <span style=\"color:#e74c3c;\"><code>\\<\/code><\/span>\uc785\ub2c8\ub2e4. \uc989, <span style=\"color:#e74c3c;\"><code>A\\B<\/code><\/span>\ub294 $A$\uc5d0\ub9cc \uc18d\ud558\uace0 $B$\uc5d0\ub294 \uc18d\ud558\uc9c0 \uc54a\ub294 \uc6d0\uc18c\ub4e4\ub9cc\uc774 \uc18d\ud558\ub294 \uc9d1\ud569\uc785\ub2c8\ub2e4.<\/li>\r\n\t<li>&lsquo;\ube7c\ubc84\ub824&rsquo;\uc758 \uc5f0\uc0b0\uc790 \uc6b0\uc120\uc21c\uc704\ub294 <span style=\"color:#e74c3c;\"><code>&amp;<\/code><\/span>\uac00 \uac00\uc7a5 \ub192\uace0, \uadf8 \ub2e4\uc74c\uc774 <span style=\"color:#e74c3c;\"><code>\\<\/code><\/span>, \ub9c8\uc9c0\ub9c9\uc73c\ub85c <span style=\"color:#e74c3c;\"><code>|<\/code><\/span> \uc21c\uc785\ub2c8\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\uc740\ud558\ub294 &lsquo;\uc544\ub2c8\uc57c&rsquo;\uc758 \uad6c\ud604\uccb4\ub97c \ub9cc\ub4dc\ub294 \ub370\uc5d0 \uc5c4\uccad\ub098\uac8c \ube60\ub978 &lsquo;\ube7c\ubc84\ub824&rsquo;\uc758 \uad6c\ud604\uccb4\ub97c \uc774\uc6a9\ud560 \uc0dd\uac01\uc744 \ud588\uc2b5\ub2c8\ub2e4. \uadf8\ub7ec\ub824\uba74 &lsquo;\uc544\ub2c8\uc57c&rsquo;\uc758 \uc2dd\uc744 \uc785\ub825\ubc1b\uc544 \ube60\ub978 \uc2dc\uac04 \uc548\uc5d0 \ub2e4\uc74c\uacfc \uac19\uc740 \uc870\uac74\uc744 \ub9cc\uc871\ud558\ub294&nbsp;&lsquo;\ube7c\ubc84\ub824&rsquo;\uc758 \uc2dd\uc73c\ub85c \ubc14\uafb8\uc5b4 \uc8fc\ub294 <strong>\ud2b8\ub79c\uc2a4\ud30c\uc77c\ub7ec<\/strong>\uac00 \ud544\uc694\ud569\ub2c8\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>\ub2f9\uc5f0\ud788, &lsquo;\uc544\ub2c8\uc57c&rsquo;\uc758 \uc6d0\ub798 \uc2dd\uc744 \ub3d9\ub4f1\ud55c &lsquo;\ube7c\ubc84\ub824&rsquo;\uc758 \uc2dd\uc73c\ub85c \ubc14\uafbc \uacb0\uacfc\ub294 <strong>\uc6d0\ub798 \uc2dd\uacfc \ub3d9\uc77c\ud55c \uc9d1\ud569\uc744 \ud45c\ud604<\/strong>\ud574\uc57c \ud569\ub2c8\ub2e4.<\/li>\r\n\t<li>&lsquo;\ube7c\ubc84\ub824&rsquo;\uc5d0\uc11c\uc758 \ub9e5\ub77d\uc740 &lsquo;\uc544\ub2c8\uc57c&rsquo;\uc5d0\uc11c\uc758 \ub9e5\ub77d\uacfc \ub3d9\uc77c\ud558\ubbc0\ub85c, &lsquo;\uc544\ub2c8\uc57c&rsquo;\uc758 \uc6d0\ub798 \uc2dd\uc744 \ub3d9\ub4f1\ud55c &lsquo;\ube7c\ubc84\ub824&rsquo;\uc758 \uc2dd\uc73c\ub85c \ubc14\uafbc \uacb0\uacfc\ub294 <strong>\uc6d0\ub798 \uc2dd\uc5d0 \ub4f1\uc7a5\ud558\ub294 \uc9d1\ud569\ub9cc\uc744 \uc0ac\uc6a9<\/strong>\ud574\uc57c \ud569\ub2c8\ub2e4.<\/li>\r\n\t<li>\uc544\ubb34\ub9ac &lsquo;\ube7c\ubc84\ub824&rsquo;\uac00 \ube60\ub978 \uad6c\ud604\uccb4\ub77c\ub3c4, \uae34 \uc2dd\uc744 \ucc98\ub9ac\ud558\ub294 \ub370\uc5d0\ub294 \uc624\ub79c \uc2dc\uac04\uc774 \uac78\ub9b4 \uac83\uc785\ub2c8\ub2e4. \ub530\ub77c\uc11c &lsquo;\uc544\ub2c8\uc57c&rsquo;\uc758 \uc6d0\ub798 \uc2dd\uc744 \ub3d9\ub4f1\ud55c &lsquo;\ube7c\ubc84\ub824&rsquo;\uc758 \uc2dd\uc73c\ub85c \ubc14\uafbc \uacb0\uacfc\ub294 <strong>\uc6d0\ub798 \uc2dd\uc758 \uae38\uc774\uc758 $2$\ubc30\ub97c \ub118\uc5b4\uc11c\ub294 \uc548 \ub429\ub2c8\ub2e4<\/strong>.<\/li>\r\n<\/ul>\r\n\r\n<p>\uc740\ud558\ub97c \ub3c4\uc640 \uc774 \ud2b8\ub79c\uc2a4\ud30c\uc77c\ub7ec\ub97c \uc791\uc131\ud569\uc2dc\ub2e4!<\/p>\r\n","input":"<p>\uccab \uc904\uc5d0 \uc62c\ubc14\ub978 &lsquo;\uc544\ub2c8\uc57c&rsquo;\uc758 \uc2dd\uc774 \uc8fc\uc5b4\uc9d1\ub2c8\ub2e4. \uc2dd\uc740 \uacf5\ubc31 \uc5c6\uc774 \uc8fc\uc5b4\uc9c0\uba70, $2024$\uc790 \uc774\ud558\uc785\ub2c8\ub2e4.<\/p>\r\n","output":"<p>\uccab \uc904\uc5d0, \uc8fc\uc5b4\uc9c4 &lsquo;\uc544\ub2c8\uc57c&rsquo;\uc758 \uc2dd\uc744 \uc9c0\ubb38\uc5d0\uc11c \uc124\uba85\ud55c \uc870\uac74\uc744 \ub9cc\uc871\ud558\ub294 &lsquo;\ube7c\ubc84\ub824&rsquo;\uc758 \uc2dd\uc73c\ub85c \ubc14\uafc0 \uc218 \uc788\ub2e4\uba74 <span style=\"color:#e74c3c;\"><code>YES<\/code><\/span>\ub97c, \uadf8\ub807\uc9c0 \uc54a\ub2e4\uba74 <span style=\"color:#e74c3c;\"><code>NO<\/code><\/span>\ub97c \ucd9c\ub825\ud569\ub2c8\ub2e4.<\/p>\r\n\r\n<p>\uccab \uc904\uc5d0 <span style=\"color:#e74c3c;\"><code>YES<\/code><\/span>\ub97c \ucd9c\ub825\ud588\ub2e4\uba74, \ub458\uc9f8 \uc904\uc5d0 \uc9d1\ud569 \uc2dd\uc744 \ucd9c\ub825\ud569\ub2c8\ub2e4. \uc774 \uc2dd\uc740 \uacf5\ubc31\uc744 \ud3ec\ud568\ud558\uc9c0 \uc54a\ub294 \uc62c\ubc14\ub978 &lsquo;\ube7c\ubc84\ub824&rsquo;\uc758 \uc2dd\uc774\uc5b4\uc57c \ud558\uba70, \uc9c0\ubb38\uc5d0\uc11c \uc124\uba85\ud55c \uc870\uac74\uc744 \ub9cc\uc871\ud574\uc57c \ud569\ub2c8\ub2e4.<\/p>\r\n","hint":"<p>&lsquo;\uc544\ub2c8\uc57c&rsquo;\uc640 &lsquo;\ube7c\ubc84\ub824&rsquo;\uc758 BNF(Backus-Naur Form)\ub294 \ub2e4\uc74c\uacfc \uac19\uc2b5\ub2c8\ub2e4. \uc785\ub825\uc73c\ub85c\ub294 &lsquo;\uc544\ub2c8\uc57c&rsquo;\uc758 <code>Expression<\/code>\uc774 \uc8fc\uc5b4\uc9c0\uace0, \uc5ec\ub7ec\ubd84\uc740 &lsquo;\ube7c\ubc84\ub824&rsquo;\uc758 <code>Expression<\/code>\uc744 \ucd9c\ub825\ud574\uc57c \ud569\ub2c8\ub2e4. <span style=\"color:#e74c3c;\"><code>[1]<\/code><\/span>\uc740 &lsquo;\uc544\ub2c8\uc57c&rsquo;\uc5d0\uc11c\ub9cc, <span style=\"color:#e74c3c;\"><code>[2]<\/code><\/span>\ub294 &lsquo;\ube7c\ubc84\ub824&rsquo;\uc5d0\uc11c\ub9cc \uc0ac\uc6a9 \uac00\ub2a5\ud569\ub2c8\ub2e4.<\/p>\r\n<style type=\"text\/css\">.nb td, .nb {\r\n    border: none !important;\r\n    vertical-align: middle !important;\r\n}\r\n<\/style>\r\n<center>\r\n<div style=\"text-align: center;\">\r\n<table border=\"1\" cellpadding=\"1\" cellspacing=\"1\" class=\"nb table table-bordered\" style=\"max-width: 25em; margin: 0px auto;\">\r\n\t<tbody>\r\n\t\t<tr>\r\n\t\t\t<td>\r\n\t\t\t<p style=\"text-align: left;\"><code>Expresssion =<br \/>\r\n\t\t\t&nbsp; | Set<br \/>\r\n\t\t\t&nbsp; | &quot;~&quot; Expression&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <span style=\"color:#e74c3c;\"># [1]<\/span><br \/>\r\n\t\t\t&nbsp; | Expression &quot;&amp;&quot; Expression<br \/>\r\n\t\t\t&nbsp; | Expression &quot;\\&quot; Expression <span style=\"color:#e74c3c;\"># [2]<\/span><br \/>\r\n\t\t\t&nbsp; | Expression &quot;|&quot; Expression<br \/>\r\n\t\t\t&nbsp; | &quot;(&quot; Expression &quot;)&quot;<\/code><\/p>\r\n\r\n\t\t\t<p style=\"text-align: left;\"><code>Set =<br \/>\r\n\t\t\t&nbsp; | &quot;A&quot; | &quot;B&quot; | &quot;C&quot; | &quot;D&quot; | &quot;E&quot;<br \/>\r\n\t\t\t&nbsp; | &quot;F&quot; | &quot;G&quot; | &quot;H&quot; | &quot;I&quot; | &quot;J&quot;<br \/>\r\n\t\t\t&nbsp; | &quot;K&quot; | &quot;L&quot; | &quot;M&quot; | &quot;N&quot; | &quot;O&quot;<br \/>\r\n\t\t\t&nbsp; | &quot;P&quot; | &quot;Q&quot; | &quot;R&quot; | &quot;S&quot; | &quot;T&quot;<\/code><\/p>\r\n\t\t\t<\/td>\r\n\t\t<\/tr>\r\n\t<\/tbody>\r\n<\/table>\r\n<\/div>\r\n<\/center>\r\n","original":"1","html_title":"0","problem_lang_tcode":"Korean"},{"problem_id":"31401","problem_lang":"1","title":"Set Expression Transpile","description":"<p>Eunha has developed a new language &lsquo;Not-a-Set&rsquo; which deals with sets in a defined universal set. &lsquo;Not-a-Set&rsquo; supports the following three operators on $20$ sets from $A$ to $T$ allowing various set notations.<\/p>\r\n\r\n<ul>\r\n\t<li>Intersection: Returns a new set created from the elements common in two sets. The symbol is <span style=\"color:#e74c3c;\"><code>&amp;<\/code><\/span> (elements in <strong>both $A$ and $B$<\/strong>).<\/li>\r\n\t<li>Union: Returns a new set created from elements in at least one of two sets. The symbol is <span style=\"color:#e74c3c;\"><code>|<\/code><\/span>(elements in <strong>at least one of&nbsp;$A$ or $B$<\/strong>).<\/li>\r\n\t<li>Complement: Returns a new set created from elements not in a set. The symbol is <span style=\"color:#e74c3c;\"><code>~<\/code><\/span>(elements&nbsp;<strong>not in $A$<\/strong>).<\/li>\r\n<\/ul>\r\n\r\n<p>Operators may be combined. For example, <span style=\"color:#e74c3c;\"><code>(A|B)&amp;~C<\/code><\/span>&nbsp;denotes a new set created from the elements that are in at least one of $A$ or $B$ and not in $C$. Here, <span style=\"color:#e74c3c;\"><code>~<\/code><\/span>&nbsp;has the highest operator precedence,&nbsp;<span style=\"color:#e74c3c;\"><code>&amp;<\/code><\/span> comes next, and <span style=\"color:#e74c3c;\"><code>|<\/code><\/span>&nbsp;has the lowest operator precedence. As shown in the prior example, you may use brackets to increase the operator precedence for specific operators.<\/p>\r\n\r\n<p>However, during her research, Eunha found out about &lsquo;Subtract-It&rsquo;, a language with an&nbsp;implementation for checking whether an element is present in a given set super fast. &lsquo;Subtract-It&rsquo; works the same way as &lsquo;Not-a-Set&rsquo; except for the following differences.<\/p>\r\n\r\n<ul>\r\n\t<li>The complement operator is <strong>not supported<\/strong>.<\/li>\r\n\t<li>Instead, the <strong>difference operator<\/strong> is supported. This operator returns a new set created from elements that are only in the left of two sets. The symbol is <span style=\"color:#e74c3c;\"><code>\\<\/code><\/span>. <span style=\"color:#e74c3c;\"><code>A\\B<\/code><\/span> is the set containing elements that are only in $A$, and not in $B$.<\/li>\r\n\t<li>In &lsquo;Subtract-It&rsquo;, <span style=\"color:#e74c3c;\"><code>&amp;<\/code><\/span> has the highest operator precedence, <span style=\"color:#e74c3c;\"><code>\\<\/code><\/span>&nbsp;comes next, and <span style=\"color:#e74c3c;\"><code>|<\/code><\/span> has the lowest operator precedence.<\/li>\r\n<\/ul>\r\n\r\n<p>Eunha has came up with the idea of using the implementation from &lsquo;Subtract-It&rsquo; to develop &lsquo;Not-a-Set&rsquo;. For this, she needs an efficient <strong>transpiler <\/strong>that takes a&nbsp; &lsquo;Not-a-Set&rsquo; expression and translates it to a &lsquo;Subtract-It&rsquo; expression matching the following conditions.<\/p>\r\n\r\n<ul>\r\n\t<li>Obviously, the translated &lsquo;Subtract-It&rsquo; expression must <strong>represent the same equivalent set as the original &lsquo;Not-a-Set&rsquo; expression. <\/strong><\/li>\r\n\t<li>Since the context is equal for &lsquo;Subtract-It&rsquo; and &lsquo;Not-a-Set&rsquo;, the translated &lsquo;Subtract-It&rsquo; expression <strong>must use only the sets which appear in the original &lsquo;Not-a-Set&rsquo; expression.<\/strong><\/li>\r\n\t<li>Although &lsquo;Subtract-It&rsquo; has a&nbsp;fast&nbsp;implementation, it still takes a long time to process long expressions. Therefore, the translated&nbsp;&lsquo;Subtract-It&rsquo; expression <strong>must not be longer than twice the length of the original &lsquo;Not-a-Set&rsquo; expression.<\/strong><\/li>\r\n<\/ul>\r\n\r\n<p>Help Eunha write this transpiler!<\/p>\r\n","input":"<p>The first line of input contains a &lsquo;Not-a-Set&rsquo; expression. The length of the expression does not exceed $2024$, and the expression does not contain any spaces.<\/p>\r\n","output":"<p>The first line of output should contain whether it is possible to translate the given &lsquo;Not-a-Set&rsquo; expression to an equivalent &lsquo;Subtract-It&rsquo; expression matching the conditions given in the problem statement. If it is possible, print <span style=\"color:#e74c3c;\"><code>YES<\/code><\/span>. Otherwise, print <span style=\"color:#e74c3c;\"><code>NO<\/code><\/span>.<\/p>\r\n\r\n<p>If the first line of output was <span style=\"color:#e74c3c;\"><code>YES<\/code><\/span>, print the set expression. This expression must be a valid &lsquo;Subtract-It&rsquo; expression without any spaces and must match the conditions given in the problem statement.<\/p>\r\n","hint":"<p>The BNF(Backus-Naur Form) of &lsquo;Not-a-Set&rsquo; and &lsquo;Subtract-It&rsquo; are as follows. The <code>Expression<\/code>&nbsp;for &lsquo;Not-a-Set&rsquo; is given, and you must print <code>Expression<\/code>&nbsp;for &lsquo;Subtract-It&rsquo;.&nbsp;<span style=\"color:#e74c3c;\"><code>[1]<\/code><\/span> can only be used in &lsquo;Not-a-Set&rsquo;, and <span style=\"color:#e74c3c;\"><code>[2]<\/code><\/span>&nbsp;can only be used in &lsquo;Subtract-It&rsquo;.<\/p>\r\n\r\n<p>\r\n<style type=\"text\/css\">.nb td, .nb {\r\n    border: none !important;\r\n    vertical-align: middle !important;\r\n}\r\n<\/style>\r\n<\/p>\r\n\r\n<center>\r\n<div style=\"text-align: center;\">\r\n<table border=\"1\" cellpadding=\"1\" cellspacing=\"1\" class=\"nb table table-bordered\" style=\"max-width: 25em; margin: 0px auto;\">\r\n\t<tbody>\r\n\t\t<tr>\r\n\t\t\t<td>\r\n\t\t\t<p style=\"text-align: left;\"><code>Expresssion =<br \/>\r\n\t\t\t&nbsp; | Set<br \/>\r\n\t\t\t&nbsp; | &quot;~&quot; Expression&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp; &nbsp; <span style=\"color:#e74c3c;\"># [1]<\/span><br \/>\r\n\t\t\t&nbsp; | Expression &quot;&amp;&quot; Expression<br \/>\r\n\t\t\t&nbsp; | Expression &quot;\\&quot; Expression <span style=\"color:#e74c3c;\"># [2]<\/span><br \/>\r\n\t\t\t&nbsp; | Expression &quot;|&quot; Expression<br \/>\r\n\t\t\t&nbsp; | &quot;(&quot; Expression &quot;)&quot;<\/code><\/p>\r\n\r\n\t\t\t<p style=\"text-align: left;\"><code>Set =<br \/>\r\n\t\t\t&nbsp; | &quot;A&quot; | &quot;B&quot; | &quot;C&quot; | &quot;D&quot; | &quot;E&quot;<br \/>\r\n\t\t\t&nbsp; | &quot;F&quot; | &quot;G&quot; | &quot;H&quot; | &quot;I&quot; | &quot;J&quot;<br \/>\r\n\t\t\t&nbsp; | &quot;K&quot; | &quot;L&quot; | &quot;M&quot; | &quot;N&quot; | &quot;O&quot;<br \/>\r\n\t\t\t&nbsp; | &quot;P&quot; | &quot;Q&quot; | &quot;R&quot; | &quot;S&quot; | &quot;T&quot;<\/code><\/p>\r\n\t\t\t<\/td>\r\n\t\t<\/tr>\r\n\t<\/tbody>\r\n<\/table>\r\n<\/div>\r\n<\/center>\r\n","original":"0","html_title":"0","problem_lang_tcode":"English"}]

출처

Contest > solved.ac > solved.ac Grand Arena #4 > Division 1 G번

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

출처

대학교 대회

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

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