시간 제한메모리 제한제출정답맞힌 사람정답 비율
1 초 128 MB71133.333%

문제

얼마전 남극 연구 탐사진들은 새로운 종을 발견하였다. 연구진은 테스트를 하기 위해 샘플을 하나 추출해 연구실로 보냈다.

이번에 발견된 새로운 종은 짧은 주기를 갖고 번식한다. 번식할 때 부모는 하나만 있으면 된다. 한 부모는 두 번 번식할 수 있으며, 그 이후에는 더 이상 번식할 수 없다.

따라서, 연구실에 있는 표본의 수는 급속도로 늘어났고, 가계도가 필요한 시점이 되었다.

연구진은 간단한 텍스트 에디터를 이용해 가계도를 그리려고 한다. 가계도는 다음과 같은 규칙을 지켜야 한다.

표번의 이름은 '-', '|', 'o'로 이루어진 박스로 둘러쌓여져 있어야 한다. 윗 변과 아랫 변의 중앙에는 '+' 마크가 있어야 한다. 변의 길이가 짝수인 경우에는 두 중앙 중 왼쪽 중앙에 '+'를 표시한다.

o--+--o
|anton|
o--+--o
o----+----o
|anamarija|
o----+----o
o-+--o
|pero|
o-+--o

박스를 링크를 이용해 연결해야 한다. 한 링크는 두 개 또는 그 이상의 박스를 연결할 수 있으며, '+'와 연결되어 있어야 한다. 부모 박스가 위에, 자식 박스가 아래에 있어야 한다. 박스와 링크는 겹칠 수 없다.

+
|
o
|
+
    +    
    |    
o---o---o
|       |
+       +
      +      
      |      
o-----o-----o
|           |
+           +

자식의 수가 1개인 경우에는 가장 왼쪽 그림에 나와있는 링크를 사용한다. 둘 이상의 자식을 가지는 경우에는 중간에 갈라진 링크를 사용해야 하며, 왼쪽에는 나이가 많은 자식, 오른쪽에는 적은 자식이 있어야 한다.

링크는 수평방향으로 늘어날 수 있으며, 좌우의 '-'의 개수는 같아야 한다. 링크는 수직방향으로 늘어날 수는 없다.

각 표본의 정보가 주어졌을 때, 가계도를 그리는데 필요한 문자의 개수를 구하는 프로그램을 작성하시오. 단, 공백의 개수는 세지 않으며, '-', '|', '+', 'o', 이름만 센다.

입력

첫째 줄에 실험실에 있는 표본의 수 N (1 ≤ N ≤ 300,000)이 주어진다. 각 표본은 1번부터 N번까지 태어난 순서대로 번호가 매겨져 있다. 즉, 가장 나이가 많은 표본은 1, 어린 표본은 N이다.

다음 N개 줄에는 각 표본의 이름과 부모의 번호가 주어진다. (첫 번째 표본의 부모는 알 수 없다) 이름은 알파벳 소문자로만 이루어진 문자열로 길이는 20을 넘지 않는다.

출력

첫째 줄에 가계도를 그리는데 필요한 글자의 수를 출력한다.

예제 입력 1

3
adam
kain 1
abel 1

예제 출력 1

64
   o-+--o   
   |adam|   
   o-+--o   
     |      
  o--o--o   
  |     |   
o-+--oo-+--o
|kain||abel|
o-+--oo-+--o

예제 입력 2

12
anton
ana 1
luka 1
mia 2
tea 3
jakov 3
semiramida 5
dominik 5
anamarija 4
eustahije 4
lovro 2
lovro 11

예제 출력 2

371
                             o--+--o                 
                             |anton|                 
                             o--+--o                 
                                |                    
                   o------------o------------o       
                   |                         |       
                 o-+-o                     o-+--o    
                 |ana|                     |luka|    
                 o-+-o                     o-+--o    
                   |                         |       
           o-------o-------o              o--o--o    
           |               |              |     |    
         o-+-o          o--+--o         o-+-oo--+--o 
         |mia|          |lovro|         |tea||jakov| 
         o-+-o          o--+--o         o-+-oo--+--o 
           |               |              |          
     o-----o-----o         o        o-----o-----o    
     |           |         |        |           |    
o----+----o o----+----o o--+--oo----+-----o o---+---o
|anamarija| |eustahije| |lovro||semiramida| |dominik|
o----+----o o----+----o o--+--oo----+-----o o---+---o
[{"problem_id":"2883","problem_lang":"0","title":"\ub0a8\uadf9\uc758 \uacfc\ud559\uc790","description":"<p>\uc5bc\ub9c8\uc804 \ub0a8\uadf9 \uc5f0\uad6c \ud0d0\uc0ac\uc9c4\ub4e4\uc740 \uc0c8\ub85c\uc6b4 \uc885\uc744 \ubc1c\uacac\ud558\uc600\ub2e4. \uc5f0\uad6c\uc9c4\uc740 \ud14c\uc2a4\ud2b8\ub97c \ud558\uae30 \uc704\ud574 \uc0d8\ud50c\uc744 \ud558\ub098 \ucd94\ucd9c\ud574 \uc5f0\uad6c\uc2e4\ub85c \ubcf4\ub0c8\ub2e4.<\/p>\r\n\r\n<p>\uc774\ubc88\uc5d0 \ubc1c\uacac\ub41c \uc0c8\ub85c\uc6b4 \uc885\uc740 \uc9e7\uc740 \uc8fc\uae30\ub97c \uac16\uace0 \ubc88\uc2dd\ud55c\ub2e4. \ubc88\uc2dd\ud560 \ub54c \ubd80\ubaa8\ub294 \ud558\ub098\ub9cc \uc788\uc73c\uba74 \ub41c\ub2e4. \ud55c \ubd80\ubaa8\ub294 \ub450 \ubc88 \ubc88\uc2dd\ud560 \uc218 \uc788\uc73c\uba70, \uadf8 \uc774\ud6c4\uc5d0\ub294 \ub354 \uc774\uc0c1 \ubc88\uc2dd\ud560 \uc218 \uc5c6\ub2e4.<\/p>\r\n\r\n<p>\ub530\ub77c\uc11c, \uc5f0\uad6c\uc2e4\uc5d0 \uc788\ub294 \ud45c\ubcf8\uc758 \uc218\ub294 \uae09\uc18d\ub3c4\ub85c \ub298\uc5b4\ub0ac\uace0, \uac00\uacc4\ub3c4\uac00 \ud544\uc694\ud55c \uc2dc\uc810\uc774 \ub418\uc5c8\ub2e4.<\/p>\r\n\r\n<p>\uc5f0\uad6c\uc9c4\uc740 \uac04\ub2e8\ud55c \ud14d\uc2a4\ud2b8 \uc5d0\ub514\ud130\ub97c \uc774\uc6a9\ud574 \uac00\uacc4\ub3c4\ub97c \uadf8\ub9ac\ub824\uace0 \ud55c\ub2e4. \uac00\uacc4\ub3c4\ub294 \ub2e4\uc74c\uacfc \uac19\uc740 \uaddc\uce59\uc744 \uc9c0\ucf1c\uc57c \ud55c\ub2e4.<\/p>\r\n\r\n<p>\ud45c\ubc88\uc758 \uc774\ub984\uc740 &#39;<code>-<\/code>&#39;, &#39;<code>|<\/code>&#39;, &#39;<code>o<\/code>&#39;\ub85c \uc774\ub8e8\uc5b4\uc9c4 \ubc15\uc2a4\ub85c \ub458\ub7ec\uc313\uc5ec\uc838 \uc788\uc5b4\uc57c \ud55c\ub2e4. \uc717 \ubcc0\uacfc \uc544\ub7ab \ubcc0\uc758 \uc911\uc559\uc5d0\ub294 &#39;<code>+<\/code>&#39; \ub9c8\ud06c\uac00 \uc788\uc5b4\uc57c \ud55c\ub2e4. \ubcc0\uc758 \uae38\uc774\uac00 \uc9dd\uc218\uc778 \uacbd\uc6b0\uc5d0\ub294 \ub450 \uc911\uc559 \uc911 \uc67c\ucabd \uc911\uc559\uc5d0 &#39;<code>+<\/code>&#39;\ub97c \ud45c\uc2dc\ud55c\ub2e4.<\/p>\r\n\r\n<table class=\"table table-bordered td-center\">\r\n\t<tbody>\r\n\t\t<tr>\r\n\t\t\t<td>\r\n\t\t\t<pre>\r\no--+--o\r\n|anton|\r\no--+--o<\/pre>\r\n\t\t\t<\/td>\r\n\t\t\t<td>\r\n\t\t\t<pre>\r\no----+----o\r\n|anamarija|\r\no----+----o<\/pre>\r\n\t\t\t<\/td>\r\n\t\t\t<td>\r\n\t\t\t<pre>\r\no-+--o\r\n|pero|\r\no-+--o<\/pre>\r\n\t\t\t<\/td>\r\n\t\t<\/tr>\r\n\t<\/tbody>\r\n<\/table>\r\n\r\n<p>\ubc15\uc2a4\ub97c \ub9c1\ud06c\ub97c \uc774\uc6a9\ud574 \uc5f0\uacb0\ud574\uc57c \ud55c\ub2e4. \ud55c \ub9c1\ud06c\ub294 \ub450 \uac1c \ub610\ub294 \uadf8 \uc774\uc0c1\uc758 \ubc15\uc2a4\ub97c \uc5f0\uacb0\ud560 \uc218 \uc788\uc73c\uba70, &#39;<code>+<\/code>&#39;\uc640 \uc5f0\uacb0\ub418\uc5b4 \uc788\uc5b4\uc57c \ud55c\ub2e4. \ubd80\ubaa8 \ubc15\uc2a4\uac00 \uc704\uc5d0, \uc790\uc2dd \ubc15\uc2a4\uac00 \uc544\ub798\uc5d0 \uc788\uc5b4\uc57c \ud55c\ub2e4. \ubc15\uc2a4\uc640 \ub9c1\ud06c\ub294 \uacb9\uce60 \uc218 \uc5c6\ub2e4.<\/p>\r\n\r\n<table class=\"table table-bordered td-center\">\r\n\t<tbody>\r\n\t\t<tr>\r\n\t\t\t<td>\r\n\t\t\t<pre>\r\n+\r\n|\r\no\r\n|\r\n+<\/pre>\r\n\t\t\t<\/td>\r\n\t\t\t<td>\r\n\t\t\t<pre>\r\n    +    \r\n    |    \r\no---o---o\r\n|       |\r\n+       +<\/pre>\r\n\t\t\t<\/td>\r\n\t\t\t<td>\r\n\t\t\t<pre>\r\n      +      \r\n&nbsp;     |      \r\no-----o-----o\r\n|           |\r\n+           +<\/pre>\r\n\t\t\t<\/td>\r\n\t\t<\/tr>\r\n\t<\/tbody>\r\n<\/table>\r\n\r\n<p>\uc790\uc2dd\uc758 \uc218\uac00 1\uac1c\uc778 \uacbd\uc6b0\uc5d0\ub294 \uac00\uc7a5 \uc67c\ucabd \uadf8\ub9bc\uc5d0 \ub098\uc640\uc788\ub294 \ub9c1\ud06c\ub97c \uc0ac\uc6a9\ud55c\ub2e4. \ub458 \uc774\uc0c1\uc758 \uc790\uc2dd\uc744 \uac00\uc9c0\ub294 \uacbd\uc6b0\uc5d0\ub294 \uc911\uac04\uc5d0 \uac08\ub77c\uc9c4 \ub9c1\ud06c\ub97c \uc0ac\uc6a9\ud574\uc57c \ud558\uba70, \uc67c\ucabd\uc5d0\ub294 \ub098\uc774\uac00 \ub9ce\uc740 \uc790\uc2dd, \uc624\ub978\ucabd\uc5d0\ub294 \uc801\uc740 \uc790\uc2dd\uc774 \uc788\uc5b4\uc57c \ud55c\ub2e4.<\/p>\r\n\r\n<p>\ub9c1\ud06c\ub294 \uc218\ud3c9\ubc29\ud5a5\uc73c\ub85c \ub298\uc5b4\ub0a0 \uc218 \uc788\uc73c\uba70, \uc88c\uc6b0\uc758 &#39;<code>-<\/code>&#39;\uc758 \uac1c\uc218\ub294 \uac19\uc544\uc57c \ud55c\ub2e4. \ub9c1\ud06c\ub294 \uc218\uc9c1\ubc29\ud5a5\uc73c\ub85c \ub298\uc5b4\ub0a0 \uc218\ub294 \uc5c6\ub2e4.<\/p>\r\n\r\n<p>\uac01 \ud45c\ubcf8\uc758 \uc815\ubcf4\uac00 \uc8fc\uc5b4\uc84c\uc744 \ub54c, \uac00\uacc4\ub3c4\ub97c \uadf8\ub9ac\ub294\ub370 \ud544\uc694\ud55c \ubb38\uc790\uc758 \uac1c\uc218\ub97c \uad6c\ud558\ub294 \ud504\ub85c\uadf8\ub7a8\uc744 \uc791\uc131\ud558\uc2dc\uc624. \ub2e8, \uacf5\ubc31\uc758 \uac1c\uc218\ub294 \uc138\uc9c0 \uc54a\uc73c\uba70, &#39;<code>-<\/code>&#39;, &#39;<code>|<\/code>&#39;, &#39;<code>+<\/code>&#39;, &#39;<code>o<\/code>&#39;, \uc774\ub984\ub9cc \uc13c\ub2e4.<\/p>\r\n","input":"<p>\uccab\uc9f8 \uc904\uc5d0 \uc2e4\ud5d8\uc2e4\uc5d0 \uc788\ub294 \ud45c\ubcf8\uc758 \uc218 N (1 &le; N &le; 300,000)\uc774 \uc8fc\uc5b4\uc9c4\ub2e4. \uac01 \ud45c\ubcf8\uc740 1\ubc88\ubd80\ud130 N\ubc88\uae4c\uc9c0 \ud0dc\uc5b4\ub09c \uc21c\uc11c\ub300\ub85c \ubc88\ud638\uac00 \ub9e4\uaca8\uc838 \uc788\ub2e4. \uc989, \uac00\uc7a5 \ub098\uc774\uac00 \ub9ce\uc740 \ud45c\ubcf8\uc740 1, \uc5b4\ub9b0 \ud45c\ubcf8\uc740 N\uc774\ub2e4.<\/p>\r\n\r\n<p>\ub2e4\uc74c N\uac1c \uc904\uc5d0\ub294 \uac01 \ud45c\ubcf8\uc758 \uc774\ub984\uacfc \ubd80\ubaa8\uc758 \ubc88\ud638\uac00 \uc8fc\uc5b4\uc9c4\ub2e4. (\uccab \ubc88\uc9f8 \ud45c\ubcf8\uc758 \ubd80\ubaa8\ub294 \uc54c \uc218 \uc5c6\ub2e4) \uc774\ub984\uc740 \uc54c\ud30c\ubcb3 \uc18c\ubb38\uc790\ub85c\ub9cc \uc774\ub8e8\uc5b4\uc9c4 \ubb38\uc790\uc5f4\ub85c \uae38\uc774\ub294 20\uc744 \ub118\uc9c0 \uc54a\ub294\ub2e4.<\/p>\r\n","output":"<p>\uccab\uc9f8 \uc904\uc5d0 \uac00\uacc4\ub3c4\ub97c \uadf8\ub9ac\ub294\ub370 \ud544\uc694\ud55c \uae00\uc790\uc758 \uc218\ub97c \ucd9c\ub825\ud55c\ub2e4.<\/p>\r\n","hint":"","original":"0","html_title":"0","problem_lang_tcode":"Korean","sample_explain_1":"<pre style=\"text-align: center;\">\r\n   o-+--o   \r\n&nbsp;  |adam|   \r\n&nbsp;  o-+--o   \r\n&nbsp;    |      \r\n&nbsp; o--o--o   \r\n&nbsp; |     |   \r\no-+--oo-+--o\r\n|kain||abel|\r\no-+--oo-+--o<\/pre>\r\n","sample_explain_2":"<pre style=\"text-align: center;\">\r\n                             o--+--o                 \r\n                             |anton|                 \r\n                             o--+--o                 \r\n                                |                    \r\n                   o------------o------------o       \r\n                   |                         |       \r\n                 o-+-o                     o-+--o    \r\n                 |ana|                     |luka|    \r\n                 o-+-o                     o-+--o    \r\n                   |                         |       \r\n           o-------o-------o              o--o--o    \r\n           |               |              |     |    \r\n         o-+-o          o--+--o         o-+-oo--+--o \r\n         |mia|          |lovro|         |tea||jakov| \r\n         o-+-o          o--+--o         o-+-oo--+--o \r\n           |               |              |          \r\n     o-----o-----o         o        o-----o-----o    \r\n     |           |         |        |           |    \r\no----+----o o----+----o o--+--oo----+-----o o---+---o\r\n|anamarija| |eustahije| |lovro||semiramida| |dominik|\r\no----+----o o----+----o o--+--oo----+-----o o---+---o\r\n<\/pre>\r\n"},{"problem_id":"2883","problem_lang":"1","title":"LOZA","description":"<p>Scientists on Antarctica have found a new species! They extracted one sample and took it to the laboratory for testing.&nbsp;<\/p>\r\n\r\n<p>They quickly noticed the species reproduces quite often and that only one parent is required for reproduction. However after the parent reproduces twice, it becomes sterile and cannot reproduce again.&nbsp;<\/p>\r\n\r\n<p>In spite of this the number of specimens in the laboratory skyrocketed and the need for family trees appeared.&nbsp;<\/p>\r\n\r\n<p>They decided to draw the tree in a simple text editor using following conventions:&nbsp;<\/p>\r\n\r\n<p>The names of the specimens will be written inside nice boxes using characters &#39;<code>-<\/code>&#39;, &#39;<code>|<\/code>&#39; and &#39;<code>o<\/code>&#39;. The center point of the upper and lower border will be marked by the character &#39;<code>+<\/code>&#39;. If the length of the border is even, &#39;<code>+<\/code>&#39; will be on the left of the two center points.&nbsp;<\/p>\r\n\r\n<table class=\"table table-bordered td-center\">\r\n\t<tbody>\r\n\t\t<tr>\r\n\t\t\t<td>\r\n\t\t\t<pre>\r\no--+--o\r\n|anton|\r\no--+--o<\/pre>\r\n\t\t\t<\/td>\r\n\t\t\t<td>\r\n\t\t\t<pre>\r\no----+----o\r\n|anamarija|\r\no----+----o<\/pre>\r\n\t\t\t<\/td>\r\n\t\t\t<td>\r\n\t\t\t<pre>\r\no-+--o\r\n|pero|\r\no-+--o<\/pre>\r\n\t\t\t<\/td>\r\n\t\t<\/tr>\r\n\t<\/tbody>\r\n<\/table>\r\n\r\n<p>The boxes will be connected with links. One link connects two or more boxes on their respective &#39;<code>+<\/code>&#39; characters, with the parent specimen placed above it&#39;s children. The boxes and links must not overlap.&nbsp;<\/p>\r\n\r\n<table class=\"table table-bordered td-center\">\r\n\t<tbody>\r\n\t\t<tr>\r\n\t\t\t<td>\r\n\t\t\t<pre>\r\n+\r\n|\r\no\r\n|\r\n+<\/pre>\r\n\t\t\t<\/td>\r\n\t\t\t<td>\r\n\t\t\t<pre>\r\n    +    \r\n    |    \r\no---o---o\r\n|       |\r\n+       +<\/pre>\r\n\t\t\t<\/td>\r\n\t\t\t<td>\r\n\t\t\t<pre>\r\n      +      \r\n&nbsp;     |      \r\no-----o-----o\r\n|           |\r\n+           +<\/pre>\r\n\t\t\t<\/td>\r\n\t\t<\/tr>\r\n\t<\/tbody>\r\n<\/table>\r\n\r\n<p>If the parent has one child, a point to point (leftmost example) link is used. If the parent has two children, a branching link is used, with the older child on the left, and the younger on the right.&nbsp;<\/p>\r\n\r\n<p>Branching links may be expanded in the horizontal direction as long as the number of &#39;<code>-<\/code>&#39; characters on both sides stays equal. Links cannot be expanded vertically.&nbsp;<\/p>\r\n\r\n<p>Don&#39;t worry, you will not be asked to draw the tree, only determine the number of characters required to draw it. Space characters are not counted, only &#39;<code>-<\/code>&#39;, &#39;<code>|<\/code>&#39;, &#39;<code>+<\/code>&#39; , &#39;<code>o<\/code>&#39; and letters in the names.&nbsp;<\/p>\r\n","input":"<p>The first line of input contains one integer N (1 &le; N &le; 300 000), number of specimens in the laboratory.&nbsp;<\/p>\r\n\r\n<p>The specimens are marked with numbers 1 to N in the order of birth, with the oldest marked 1 and youngest marked N.&nbsp;<\/p>\r\n\r\n<p>The next N lines contain birth notes of all specimens in the order of birth. Each specimen (except the first whose parent is unknown) is described with two pieces of information:&nbsp;<\/p>\r\n\r\n<ul>\r\n\t<li>name - sequence of at most 20 lowercase english alphabet characters&nbsp;<\/li>\r\n\t<li>parent &ndash; one integer denoting the parent of this specimen&nbsp;<\/li>\r\n<\/ul>\r\n","output":"<p>The first and only line of input should contain the minimal number of characters needed to draw the family tree.<\/p>\r\n","hint":"","original":"1","html_title":"0","problem_lang_tcode":"English","sample_explain_1":"<pre style=\"text-align: center;\">\r\n   o-+--o   \r\n&nbsp;  |adam|   \r\n&nbsp;  o-+--o   \r\n&nbsp;    |      \r\n&nbsp; o--o--o   \r\n&nbsp; |     |   \r\no-+--oo-+--o\r\n|kain||abel|\r\no-+--oo-+--o<\/pre>\r\n","sample_explain_2":"<pre style=\"text-align: center;\">\r\n                             o--+--o                 \r\n                             |anton|                 \r\n                             o--+--o                 \r\n                                |                    \r\n                   o------------o------------o       \r\n                   |                         |       \r\n                 o-+-o                     o-+--o    \r\n                 |ana|                     |luka|    \r\n                 o-+-o                     o-+--o    \r\n                   |                         |       \r\n           o-------o-------o              o--o--o    \r\n           |               |              |     |    \r\n         o-+-o          o--+--o         o-+-oo--+--o \r\n         |mia|          |lovro|         |tea||jakov| \r\n         o-+-o          o--+--o         o-+-oo--+--o \r\n           |               |              |          \r\n     o-----o-----o         o        o-----o-----o    \r\n     |           |         |        |           |    \r\no----+----o o----+----o o--+--oo----+-----o o---+---o\r\n|anamarija| |eustahije| |lovro||semiramida| |dominik|\r\no----+----o o----+----o o--+--oo----+-----o o---+---o\r\n<\/pre>\r\n"}]