시간 제한메모리 제한제출정답맞힌 사람정답 비율
4 초 1024 MB333100.000%

문제

하이비는 최근 바이히가 만든 두뇌 게임 Operation: Path Query, Remastered - Static Tree (Updated Version)을 플레이하고 있다. 이 게임의 규칙은 다음과 같다.

  • $N$개의 정점을 가진 트리가 주어진다. 각 정점에는 $1$번부터 $N$번까지의 번호가 매겨져 있으며, 각 간선에는 $1$번부터 $N-1$번까지의 번호가 매겨져 있다.
  • $3N-1$개의 정수 카드와 $N-1$개의 연산자 카드를 사용한다.
    • 정수 카드에는 $2$자리의 음이 아닌 정수가 적혀있다. 카드에 적힌 수는 $0$으로 시작할 수 있다.
    • 연산자 카드에는 $+$, $-$, $\times$, $\div$ 중 하나의 연산자가 적혀있다.
  • $1$ 이상 $N$ 이하의 정수 $v$에 대해, $v$번 정점의 왼쪽에 정수 카드 $A_v$, 오른쪽에 정수 카드 $B_v$를 놓는다.
  • $1$ 이상 $N-1$ 이하의 정수 $e$에 대해, $e$번 간선의 왼쪽에 연산자 카드 $P_e$, 오른쪽에 정수 카드 $C_e$를 놓는다.
  • 카드를 모두 놓으면 게임이 시작한다. 게임이 진행되면서 다음과 같은 이벤트가 총 $Q$번 발생한다.
    • 질문: 두 정점 번호 $x$, $y$가 주어질 때 $x$번 정점에서 출발해서 $y$번 정점으로 끝나는 경로 내의 카드를 모두 나열한 뒤 나오는 수식의 값을 계산해야 한다.
    • $A_x$ 변경: 정점 번호 $x$와 정수 $y$가 주어질 때 $x$번 정점의 왼쪽에 놓인 정수 카드를 $y$가 적힌 정수 카드로 변경한다.
    • $B_x$ 변경: 정점 번호 $x$와 정수 $y$가 주어질 때 $x$번 정점의 오른쪽에 놓인 정수 카드를 $y$가 적힌 정수 카드로 변경한다.
    • $P_x$ 변경: 간선 번호 $x$와 연산자 $y$가 주어질 때 $x$번 간선의 왼쪽에 놓인 연산자 카드를 $y$가 적힌 연산자 카드로 변경한다.
    • $C_x$ 변경: 간선 번호 $x$와 정수 $y$가 주어질 때 $x$번 간선의 오른쪽에 놓인 정수 카드를 $y$가 적힌 정수 카드로 변경한다.
  • 질문에 답할 때는 아래 사항들을 주의해야 한다.
    • 연산자 우선순위는 무시하고 왼쪽에서 오른쪽 순서로 연산한다.
    • 경로 내의 카드를 나열할 때는 출발점에서 가까운 정점 또는 간선에 놓인 카드부터 나열해야 한다. 또한, 정점 또는 간선의 왼쪽에 놓인 카드를 오른쪽에 놓인 카드보다 먼저 나열해야 한다. 예를 들어, 경로가 $x$번 정점 → $a$번 간선 → $b$번 정점 → $c$번 간선 → $y$번 정점이라고 하자. 이 경우 $A_x$, $B_x$, $P_a$, $C_a$, $A_b$, $B_b$, $P_c$, $C_c$, $A_y$, $B_y$의 순서대로 카드를 나열해야 한다.
    • 정수 카드가 여러 개 연속되어 놓이는 경우, 해당하는 정수를 이어 붙여서 하나의 수로 보아야 한다. 예를 들어, 나열된 카드가 $12$, $57$, $+$, $12$, $03$, $17$이라면 계산해야 하는 값은 $12\, 57+12\, 03\, 17=121\, 374$가 된다.
    • $x\div 0$은 $0$으로 계산한다.

예를 들어, 다음과 같은 트리에서 $1$번 정점에서 출발해서 $4$번 정점으로 끝나는 경로 내의 카드를 모두 이어 붙인다고 해보자.

경로 내의 카드를 모두 이어 붙인 뒤 계산하면 $07\,23 + 27\,06\,24 - 35\,13\,26 = -79\,979$가 나온다.

하이비는 이 게임을 자주 플레이하다 보니, 매 플레이마다 모든 질문에 대해 답을 정확히 맞히는 경지에 이르렀다. 이를 바이히에게 증명하기 위해, 하이비는 게임의 진행 과정이 주어질 때 각 질문에 대한 답을 계산해 주는 프로그램을 작성해서 보여주기로 했다.

입력

첫째 줄에는 트리의 정점 개수 $N$과 플레이하는 라운드의 수 $Q$가 공백으로 구분되어 주어진다. $(1\le N,Q\le 500\, 000)$

둘째 줄부터 $N$개의 줄에 걸쳐, $i+1$번째 줄에는 $i$번 정점에 놓인 두 정수 카드 $A_i$와 $B_i$가 공백으로 구분되어 주어진다. $(00\le A_i,B_i\le 99)$

$N+2$번째 줄부터 $N-1$개의 줄에 걸쳐, $i+N+1$번째 줄에는 $i$번 간선이 잇는 두 정점 $v_i$, $w_i$과 해당 간선에 놓인 연산자 카드 $P_i$, 정수 카드 $C_i$가 공백으로 구분되어 주어진다. $(1\le v_i,w_i\le N;$ $00\le C_i\le 99;$ $P_i$는 $+$, $-$, $\times$, $\div$ 중 하나$)$

$2N+1$번째 줄부터 $Q$개의 줄에 걸쳐 문제에서 나오는 이벤트를 의미하는 글자 $t$와 이벤트를 나타내는 두 값 $x$, $y$가 공백으로 구분되어 주어진다.

  • $t=$ ?: 질문 이벤트이다. 이때 $x$, $y$는 $1 \le x, y \le N$를 만족하는 정수이다.
  • $t=$ A: $A_x$ 변경 이벤트이다. 이때 $x$, $y$는 $1 \le x \le N;$ $00 \le y \le 99$를 만족하는 정수이다.
  • $t=$ B: $B_x$ 변경 이벤트이다. 이때 $x$, $y$는 $1 \le x \le N;$ $00 \le y \le 99$를 만족하는 정수이다.
  • $t=$ P: $P_x$ 변경 이벤트이다. 이때 $x$는 $1 \le x \le N-1$를 만족하는 정수이고, $y$는 $+$, $-$, $\times$, $\div$ 중 하나이다.
  • $t=$ C: $C_x$ 변경 이벤트이다. 이때 $x$, $y$는 $1 \le x \le N-1;$ $00 \le y \le 99$를 만족하는 정수이다.

정수 카드에 적히는 수는 항상 $2$자리 정수로 주어진다. 이를 위해 앞에 불필요한 $0$이 붙을 수 있다.

연산자 카드에 적히는 연산자 $+$, $-$, $\times$, $\div$은 각각 글자 +, -, *, /로 주어진다.

출력

각 질문 이벤트에 대해 질문의 답을 기약분수로 나타낸 값을 $p/q$라고 하자. 이때, $qr\equiv p\pmod{1\, 208\, 017}$을 만족하는 $0$ 이상 $1\, 208\, 017$ 미만인 정수 $r$을 출력한다. 문제의 제한 내에서 이 정수는 각 질문에 대해 유일함을 보일 수 있다.

$1\, 208\, 017$은 소수이다.

예제 입력 1

5 6
07 23
27 63
06 24
13 26
92 31
1 3 + 27
3 4 - 35
3 5 + 14
2 5 / 16
? 1 4
A 1 87
P 3 *
B 5 09
C 4 61
? 2 1

예제 출력 1

1128038
975864

처음 들어오는 질문은 $1$번 정점에서 $4$번 정점으로 가는 경로 위의 카드를 나열해야 한다. 이를 나열하면 $07\, 23+27\, 06\, 24-35\, 13\, 26$이 나오고, 이 값은 $-79\, 277$이다. 이때 $1\cdot 1\, 128\, 038\equiv -79\, 979\pmod{1\, 208\, 017}$이므로, $1\, 128\, 038$을 출력하면 된다.

이후 $4$번의 카드 변경 이벤트가 주어진다.

이후로 들어오는 질문은 $2$번 정점에서 $1$번 정점으로 가는 경로 위의 카드를 나열해야 한다. 이를 나열하면 $27\, 63\div 61\, 92\, 09\times 14\, 06\, 24+27\, 87\, 23$이 나오고, 이 값은 $\displaystyle \frac{19\, 219\, 592\, 691}{68\, 801}$이다. 이때 $68\, 801\cdot 975\, 864\equiv 19\, 219\, 592\, 691\pmod{1\, 208\, 017}$이므로, $975\, 864$를 출력하면 된다.

[{"problem_id":"35490","problem_lang":"0","title":"[O] Operation: Path Query, Remastered - Static Tree (Updated Version)","description":"<p>\ud558\uc774\ube44\ub294 \ucd5c\uadfc \ubc14\uc774\ud788\uac00 \ub9cc\ub4e0 \ub450\ub1cc \uac8c\uc784 Operation: Path Query, Remastered - Static Tree (Updated Version)\uc744 \ud50c\ub808\uc774\ud558\uace0 \uc788\ub2e4. \uc774 \uac8c\uc784\uc758 \uaddc\uce59\uc740 \ub2e4\uc74c\uacfc \uac19\ub2e4.<\/p>\r\n\r\n<ul>\r\n<li>$N$\uac1c\uc758 \uc815\uc810\uc744 \uac00\uc9c4 \ud2b8\ub9ac\uac00 \uc8fc\uc5b4\uc9c4\ub2e4. \uac01 \uc815\uc810\uc5d0\ub294 $1$\ubc88\ubd80\ud130 $N$\ubc88\uae4c\uc9c0\uc758 \ubc88\ud638\uac00 \ub9e4\uaca8\uc838 \uc788\uc73c\uba70, \uac01 \uac04\uc120\uc5d0\ub294 $1$\ubc88\ubd80\ud130 $N-1$\ubc88\uae4c\uc9c0\uc758 \ubc88\ud638\uac00 \ub9e4\uaca8\uc838 \uc788\ub2e4.<\/li>\r\n<li>$3N-1$\uac1c\uc758 \uc815\uc218 \uce74\ub4dc\uc640 $N-1$\uac1c\uc758 \uc5f0\uc0b0\uc790 \uce74\ub4dc\ub97c \uc0ac\uc6a9\ud55c\ub2e4.\r\n<ul>\r\n<li>\uc815\uc218 \uce74\ub4dc\uc5d0\ub294 $2$\uc790\ub9ac\uc758 \uc74c\uc774 \uc544\ub2cc \uc815\uc218\uac00 \uc801\ud600\uc788\ub2e4. \uce74\ub4dc\uc5d0 \uc801\ud78c \uc218\ub294 $0$\uc73c\ub85c \uc2dc\uc791\ud560 \uc218 \uc788\ub2e4.<\/li>\r\n<li>\uc5f0\uc0b0\uc790 \uce74\ub4dc\uc5d0\ub294 $+$, $-$, $\\times$, $\\div$ \uc911 \ud558\ub098\uc758 \uc5f0\uc0b0\uc790\uac00 \uc801\ud600\uc788\ub2e4.<\/li>\r\n<\/ul>\r\n<\/li>\r\n<li>$1$ \uc774\uc0c1 $N$ \uc774\ud558\uc758 \uc815\uc218 $v$\uc5d0 \ub300\ud574, $v$\ubc88 \uc815\uc810\uc758 \uc67c\ucabd\uc5d0 \uc815\uc218 \uce74\ub4dc $A_v$, \uc624\ub978\ucabd\uc5d0 \uc815\uc218 \uce74\ub4dc $B_v$\ub97c \ub193\ub294\ub2e4.<\/li>\r\n<li>$1$ \uc774\uc0c1 $N-1$ \uc774\ud558\uc758 \uc815\uc218 $e$\uc5d0 \ub300\ud574, $e$\ubc88 \uac04\uc120\uc758 \uc67c\ucabd\uc5d0 \uc5f0\uc0b0\uc790 \uce74\ub4dc $P_e$, \uc624\ub978\ucabd\uc5d0 \uc815\uc218 \uce74\ub4dc $C_e$\ub97c \ub193\ub294\ub2e4.<\/li>\r\n<li>\uce74\ub4dc\ub97c \ubaa8\ub450 \ub193\uc73c\uba74 \uac8c\uc784\uc774 \uc2dc\uc791\ud55c\ub2e4. \uac8c\uc784\uc774 \uc9c4\ud589\ub418\uba74\uc11c \ub2e4\uc74c\uacfc \uac19\uc740 \uc774\ubca4\ud2b8\uac00 \ucd1d $Q$\ubc88 \ubc1c\uc0dd\ud55c\ub2e4.\r\n<ul>\r\n<li>\uc9c8\ubb38: \ub450 \uc815\uc810 \ubc88\ud638 $x$, $y$\uac00 \uc8fc\uc5b4\uc9c8 \ub54c $x$\ubc88 \uc815\uc810\uc5d0\uc11c \ucd9c\ubc1c\ud574\uc11c $y$\ubc88 \uc815\uc810\uc73c\ub85c \ub05d\ub098\ub294 \uacbd\ub85c \ub0b4\uc758 \uce74\ub4dc\ub97c \ubaa8\ub450 \ub098\uc5f4\ud55c \ub4a4 \ub098\uc624\ub294 \uc218\uc2dd\uc758 \uac12\uc744 \uacc4\uc0b0\ud574\uc57c \ud55c\ub2e4.<\/li>\r\n<li>$A_x$ \ubcc0\uacbd: \uc815\uc810 \ubc88\ud638 $x$\uc640 \uc815\uc218 $y$\uac00 \uc8fc\uc5b4\uc9c8 \ub54c $x$\ubc88 \uc815\uc810\uc758 \uc67c\ucabd\uc5d0 \ub193\uc778 \uc815\uc218 \uce74\ub4dc\ub97c $y$\uac00 \uc801\ud78c \uc815\uc218 \uce74\ub4dc\ub85c \ubcc0\uacbd\ud55c\ub2e4.<\/li>\r\n<li>$B_x$ \ubcc0\uacbd: \uc815\uc810 \ubc88\ud638 $x$\uc640 \uc815\uc218 $y$\uac00 \uc8fc\uc5b4\uc9c8 \ub54c $x$\ubc88 \uc815\uc810\uc758 \uc624\ub978\ucabd\uc5d0 \ub193\uc778 \uc815\uc218 \uce74\ub4dc\ub97c $y$\uac00 \uc801\ud78c \uc815\uc218 \uce74\ub4dc\ub85c \ubcc0\uacbd\ud55c\ub2e4.<\/li>\r\n<li>$P_x$ \ubcc0\uacbd: \uac04\uc120 \ubc88\ud638 $x$\uc640 \uc5f0\uc0b0\uc790 $y$\uac00 \uc8fc\uc5b4\uc9c8 \ub54c $x$\ubc88 \uac04\uc120\uc758 \uc67c\ucabd\uc5d0 \ub193\uc778 \uc5f0\uc0b0\uc790 \uce74\ub4dc\ub97c $y$\uac00 \uc801\ud78c \uc5f0\uc0b0\uc790 \uce74\ub4dc\ub85c \ubcc0\uacbd\ud55c\ub2e4.<\/li>\r\n<li>$C_x$ \ubcc0\uacbd: \uac04\uc120 \ubc88\ud638 $x$\uc640 \uc815\uc218 $y$\uac00 \uc8fc\uc5b4\uc9c8 \ub54c $x$\ubc88 \uac04\uc120\uc758 \uc624\ub978\ucabd\uc5d0 \ub193\uc778 \uc815\uc218 \uce74\ub4dc\ub97c $y$\uac00 \uc801\ud78c \uc815\uc218 \uce74\ub4dc\ub85c \ubcc0\uacbd\ud55c\ub2e4.<\/li>\r\n<\/ul>\r\n<\/li>\r\n<li>\uc9c8\ubb38\uc5d0 \ub2f5\ud560 \ub54c\ub294 \uc544\ub798 \uc0ac\ud56d\ub4e4\uc744 \uc8fc\uc758\ud574\uc57c \ud55c\ub2e4.\r\n<ul>\r\n<li>\uc5f0\uc0b0\uc790 \uc6b0\uc120\uc21c\uc704\ub294 \ubb34\uc2dc\ud558\uace0 \uc67c\ucabd\uc5d0\uc11c \uc624\ub978\ucabd \uc21c\uc11c\ub85c \uc5f0\uc0b0\ud55c\ub2e4.<\/li>\r\n<li>\uacbd\ub85c \ub0b4\uc758 \uce74\ub4dc\ub97c \ub098\uc5f4\ud560 \ub54c\ub294 \ucd9c\ubc1c\uc810\uc5d0\uc11c \uac00\uae4c\uc6b4 \uc815\uc810 \ub610\ub294 \uac04\uc120\uc5d0 \ub193\uc778 \uce74\ub4dc\ubd80\ud130 \ub098\uc5f4\ud574\uc57c \ud55c\ub2e4. \ub610\ud55c, \uc815\uc810 \ub610\ub294 \uac04\uc120\uc758 \uc67c\ucabd\uc5d0 \ub193\uc778 \uce74\ub4dc\ub97c \uc624\ub978\ucabd\uc5d0 \ub193\uc778 \uce74\ub4dc\ubcf4\ub2e4 \uba3c\uc800 \ub098\uc5f4\ud574\uc57c \ud55c\ub2e4. \uc608\ub97c \ub4e4\uc5b4, \uacbd\ub85c\uac00 $x$\ubc88 \uc815\uc810 &rarr; $a$\ubc88 \uac04\uc120 &rarr; $b$\ubc88 \uc815\uc810 &rarr; $c$\ubc88 \uac04\uc120 &rarr; $y$\ubc88 \uc815\uc810\uc774\ub77c\uace0 \ud558\uc790. \uc774 \uacbd\uc6b0 $A_x$, $B_x$, $P_a$, $C_a$, $A_b$, $B_b$, $P_c$, $C_c$, $A_y$, $B_y$\uc758 \uc21c\uc11c\ub300\ub85c \uce74\ub4dc\ub97c \ub098\uc5f4\ud574\uc57c \ud55c\ub2e4.<\/li>\r\n<li>\uc815\uc218 \uce74\ub4dc\uac00 \uc5ec\ub7ec \uac1c \uc5f0\uc18d\ub418\uc5b4 \ub193\uc774\ub294 \uacbd\uc6b0, \ud574\ub2f9\ud558\ub294 \uc815\uc218\ub97c \uc774\uc5b4 \ubd99\uc5ec\uc11c \ud558\ub098\uc758 \uc218\ub85c \ubcf4\uc544\uc57c \ud55c\ub2e4. \uc608\ub97c \ub4e4\uc5b4, \ub098\uc5f4\ub41c \uce74\ub4dc\uac00 $12$, $57$, $+$, $12$, $03$, $17$\uc774\ub77c\uba74 \uacc4\uc0b0\ud574\uc57c \ud558\ub294 \uac12\uc740 $12\\, 57+12\\, 03\\, 17=121\\, 374$\uac00 \ub41c\ub2e4.<\/li>\r\n<li>$x\\div 0$\uc740 $0$\uc73c\ub85c \uacc4\uc0b0\ud55c\ub2e4.<\/li>\r\n<\/ul>\r\n<\/li>\r\n<\/ul>\r\n\r\n<p>\uc608\ub97c \ub4e4\uc5b4, \ub2e4\uc74c\uacfc \uac19\uc740 \ud2b8\ub9ac\uc5d0\uc11c $1$\ubc88 \uc815\uc810\uc5d0\uc11c \ucd9c\ubc1c\ud574\uc11c $4$\ubc88 \uc815\uc810\uc73c\ub85c \ub05d\ub098\ub294 \uacbd\ub85c \ub0b4\uc758 \uce74\ub4dc\ub97c \ubaa8\ub450 \uc774\uc5b4 \ubd99\uc778\ub2e4\uace0 \ud574\ubcf4\uc790.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/c04c8167-5f9e-4a33-b771-8cd4e28ba915\/-\/preview\/\" style=\"width: 350px; max-width: 100%\" \/><\/p>\r\n\r\n<p>\uacbd\ub85c \ub0b4\uc758 \uce74\ub4dc\ub97c \ubaa8\ub450 \uc774\uc5b4 \ubd99\uc778 \ub4a4 \uacc4\uc0b0\ud558\uba74 $07\\,23 + 27\\,06\\,24 - 35\\,13\\,26 = -79\\,979$\uac00 \ub098\uc628\ub2e4.<\/p>\r\n\r\n<p>\ud558\uc774\ube44\ub294 \uc774 \uac8c\uc784\uc744 \uc790\uc8fc \ud50c\ub808\uc774\ud558\ub2e4 \ubcf4\ub2c8, \ub9e4 \ud50c\ub808\uc774\ub9c8\ub2e4 \ubaa8\ub4e0 \uc9c8\ubb38\uc5d0 \ub300\ud574 \ub2f5\uc744 \uc815\ud655\ud788 \ub9de\ud788\ub294 \uacbd\uc9c0\uc5d0 \uc774\ub974\ub800\ub2e4. \uc774\ub97c \ubc14\uc774\ud788\uc5d0\uac8c \uc99d\uba85\ud558\uae30 \uc704\ud574, \ud558\uc774\ube44\ub294 \uac8c\uc784\uc758 \uc9c4\ud589 \uacfc\uc815\uc774 \uc8fc\uc5b4\uc9c8 \ub54c \uac01 \uc9c8\ubb38\uc5d0 \ub300\ud55c \ub2f5\uc744 \uacc4\uc0b0\ud574 \uc8fc\ub294 \ud504\ub85c\uadf8\ub7a8\uc744 \uc791\uc131\ud574\uc11c \ubcf4\uc5ec\uc8fc\uae30\ub85c \ud588\ub2e4.<\/p>\r\n","input":"<p>\uccab\uc9f8 \uc904\uc5d0\ub294 \ud2b8\ub9ac\uc758 \uc815\uc810 \uac1c\uc218 $N$\uacfc \ud50c\ub808\uc774\ud558\ub294 \ub77c\uc6b4\ub4dc\uc758 \uc218 $Q$\uac00 \uacf5\ubc31\uc73c\ub85c \uad6c\ubd84\ub418\uc5b4 \uc8fc\uc5b4\uc9c4\ub2e4. $(1\\le N,Q\\le 500\\, 000)$<\/p>\r\n\r\n<p>\ub458\uc9f8 \uc904\ubd80\ud130 $N$\uac1c\uc758 \uc904\uc5d0 \uac78\uccd0, $i+1$\ubc88\uc9f8 \uc904\uc5d0\ub294 $i$\ubc88 \uc815\uc810\uc5d0 \ub193\uc778 \ub450 \uc815\uc218 \uce74\ub4dc $A_i$\uc640 $B_i$\uac00 \uacf5\ubc31\uc73c\ub85c \uad6c\ubd84\ub418\uc5b4 \uc8fc\uc5b4\uc9c4\ub2e4. $(00\\le A_i,B_i\\le 99)$<\/p>\r\n\r\n<p>$N+2$\ubc88\uc9f8 \uc904\ubd80\ud130 $N-1$\uac1c\uc758 \uc904\uc5d0 \uac78\uccd0, $i+N+1$\ubc88\uc9f8 \uc904\uc5d0\ub294 $i$\ubc88 \uac04\uc120\uc774 \uc787\ub294 \ub450 \uc815\uc810 $v_i$, $w_i$\uacfc \ud574\ub2f9 \uac04\uc120\uc5d0 \ub193\uc778 \uc5f0\uc0b0\uc790 \uce74\ub4dc $P_i$, \uc815\uc218 \uce74\ub4dc $C_i$\uac00 \uacf5\ubc31\uc73c\ub85c \uad6c\ubd84\ub418\uc5b4 \uc8fc\uc5b4\uc9c4\ub2e4. $(1\\le v_i,w_i\\le N;$ $00\\le C_i\\le 99;$ $P_i$\ub294 $+$, $-$, $\\times$, $\\div$ \uc911 \ud558\ub098$)$<\/p>\r\n\r\n<p>$2N+1$\ubc88\uc9f8 \uc904\ubd80\ud130 $Q$\uac1c\uc758 \uc904\uc5d0 \uac78\uccd0 \ubb38\uc81c\uc5d0\uc11c \ub098\uc624\ub294 \uc774\ubca4\ud2b8\ub97c \uc758\ubbf8\ud558\ub294 \uae00\uc790 $t$\uc640 \uc774\ubca4\ud2b8\ub97c \ub098\ud0c0\ub0b4\ub294 \ub450 \uac12 $x$, $y$\uac00 \uacf5\ubc31\uc73c\ub85c \uad6c\ubd84\ub418\uc5b4 \uc8fc\uc5b4\uc9c4\ub2e4.<\/p>\r\n\r\n<ul>\r\n<li>$t=$ <span style=\"color:#e74c3c;\"><code>?<\/code><\/span>: \uc9c8\ubb38 \uc774\ubca4\ud2b8\uc774\ub2e4. \uc774\ub54c $x$, $y$\ub294 $1 \\le x, y \\le N$\ub97c \ub9cc\uc871\ud558\ub294 \uc815\uc218\uc774\ub2e4.<\/li>\r\n<li>$t=$ <span style=\"color:#e74c3c;\"><code>A<\/code><\/span>: $A_x$ \ubcc0\uacbd \uc774\ubca4\ud2b8\uc774\ub2e4. \uc774\ub54c $x$, $y$\ub294 $1 \\le x \\le N;$ $00 \\le y \\le 99$\ub97c \ub9cc\uc871\ud558\ub294 \uc815\uc218\uc774\ub2e4.<\/li>\r\n<li>$t=$ <span style=\"color:#e74c3c;\"><code>B<\/code><\/span>: $B_x$ \ubcc0\uacbd \uc774\ubca4\ud2b8\uc774\ub2e4. \uc774\ub54c $x$, $y$\ub294 $1 \\le x \\le N;$ $00 \\le y \\le 99$\ub97c \ub9cc\uc871\ud558\ub294 \uc815\uc218\uc774\ub2e4.<\/li>\r\n<li>$t=$ <span style=\"color:#e74c3c;\"><code>P<\/code><\/span>: $P_x$ \ubcc0\uacbd \uc774\ubca4\ud2b8\uc774\ub2e4. \uc774\ub54c $x$\ub294 $1 \\le x \\le N-1$\ub97c \ub9cc\uc871\ud558\ub294 \uc815\uc218\uc774\uace0, $y$\ub294 $+$, $-$, $\\times$, $\\div$ \uc911 \ud558\ub098\uc774\ub2e4.<\/li>\r\n<li>$t=$ <span style=\"color:#e74c3c;\"><code>C<\/code><\/span>: $C_x$ \ubcc0\uacbd \uc774\ubca4\ud2b8\uc774\ub2e4. \uc774\ub54c $x$, $y$\ub294 $1 \\le x \\le N-1;$ $00 \\le y \\le 99$\ub97c \ub9cc\uc871\ud558\ub294 \uc815\uc218\uc774\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\uc815\uc218 \uce74\ub4dc\uc5d0 \uc801\ud788\ub294 \uc218\ub294 \ud56d\uc0c1 $2$\uc790\ub9ac \uc815\uc218\ub85c \uc8fc\uc5b4\uc9c4\ub2e4. \uc774\ub97c \uc704\ud574 \uc55e\uc5d0 \ubd88\ud544\uc694\ud55c $0$\uc774 \ubd99\uc744 \uc218 \uc788\ub2e4.<\/p>\r\n\r\n<p>\uc5f0\uc0b0\uc790 \uce74\ub4dc\uc5d0 \uc801\ud788\ub294 \uc5f0\uc0b0\uc790 $+$, $-$, $\\times$, $\\div$\uc740 \uac01\uac01 \uae00\uc790 <span style=\"color:#e74c3c;\"><code>+<\/code><\/span>, <span style=\"color:#e74c3c;\"><code>-<\/code><\/span>, <span style=\"color:#e74c3c;\"><code>*<\/code><\/span>, <span style=\"color:#e74c3c;\"><code>\/<\/code><\/span>\ub85c \uc8fc\uc5b4\uc9c4\ub2e4.<\/p>\r\n","output":"<p>\uac01 \uc9c8\ubb38 \uc774\ubca4\ud2b8\uc5d0 \ub300\ud574 \uc9c8\ubb38\uc758 \ub2f5\uc744 \uae30\uc57d\ubd84\uc218\ub85c \ub098\ud0c0\ub0b8 \uac12\uc744 $p\/q$\ub77c\uace0 \ud558\uc790. \uc774\ub54c, $qr\\equiv p\\pmod{1\\, 208\\, 017}$\uc744 \ub9cc\uc871\ud558\ub294 $0$ \uc774\uc0c1 $1\\, 208\\, 017$ \ubbf8\ub9cc\uc778 \uc815\uc218 $r$\uc744 \ucd9c\ub825\ud55c\ub2e4. \ubb38\uc81c\uc758 \uc81c\ud55c \ub0b4\uc5d0\uc11c \uc774 \uc815\uc218\ub294 \uac01 \uc9c8\ubb38\uc5d0 \ub300\ud574 \uc720\uc77c\ud568\uc744 \ubcf4\uc77c \uc218 \uc788\ub2e4.<\/p>\r\n\r\n<p>$1\\, 208\\, 017$\uc740 \uc18c\uc218\uc774\ub2e4.<\/p>\r\n","hint":"","original":"1","html_title":"0","problem_lang_tcode":"Korean","sample_explain_1":"<p>\ucc98\uc74c \ub4e4\uc5b4\uc624\ub294 \uc9c8\ubb38\uc740 $1$\ubc88 \uc815\uc810\uc5d0\uc11c $4$\ubc88 \uc815\uc810\uc73c\ub85c \uac00\ub294 \uacbd\ub85c \uc704\uc758 \uce74\ub4dc\ub97c \ub098\uc5f4\ud574\uc57c \ud55c\ub2e4. \uc774\ub97c \ub098\uc5f4\ud558\uba74 $07\\, 23+27\\, 06\\, 24-35\\, 13\\, 26$\uc774 \ub098\uc624\uace0, \uc774 \uac12\uc740 $-79\\, 277$\uc774\ub2e4. \uc774\ub54c $1\\cdot 1\\, 128\\, 038\\equiv -79\\, 979\\pmod{1\\, 208\\, 017}$\uc774\ubbc0\ub85c, $1\\, 128\\, 038$\uc744 \ucd9c\ub825\ud558\uba74 \ub41c\ub2e4.<\/p>\r\n\r\n<p>\uc774\ud6c4 $4$\ubc88\uc758 \uce74\ub4dc \ubcc0\uacbd \uc774\ubca4\ud2b8\uac00 \uc8fc\uc5b4\uc9c4\ub2e4.<\/p>\r\n\r\n<p>\uc774\ud6c4\ub85c \ub4e4\uc5b4\uc624\ub294 \uc9c8\ubb38\uc740 $2$\ubc88 \uc815\uc810\uc5d0\uc11c $1$\ubc88 \uc815\uc810\uc73c\ub85c \uac00\ub294 \uacbd\ub85c \uc704\uc758 \uce74\ub4dc\ub97c \ub098\uc5f4\ud574\uc57c \ud55c\ub2e4. \uc774\ub97c \ub098\uc5f4\ud558\uba74 $27\\, 63\\div 61\\, 92\\, 09\\times 14\\, 06\\, 24+27\\, 87\\, 23$\uc774 \ub098\uc624\uace0, \uc774 \uac12\uc740 $\\displaystyle \\frac{19\\, 219\\, 592\\, 691}{68\\, 801}$\uc774\ub2e4. \uc774\ub54c $68\\, 801\\cdot 975\\, 864\\equiv 19\\, 219\\, 592\\, 691\\pmod{1\\, 208\\, 017}$\uc774\ubbc0\ub85c, $975\\, 864$\ub97c \ucd9c\ub825\ud558\uba74 \ub41c\ub2e4.<\/p>\r\n"},{"problem_id":"35490","problem_lang":"1","title":"[O] Operation: Path Query, Remastered - Static Tree (Updated Version)","description":"<p>Hibee has recently been playing &#39;Operation: Path Query, Remastered - Static Tree (Updated Version)&#39;, a brain game made by Byehee. The rules of the game are as follows.<\/p>\r\n\r\n<ul>\r\n\t<li>A tree with $N$ vertices is given. The vertices are numbered starting from $1$ to $N$, and the edges are numbered starting from $1$ to $N-1$.<\/li>\r\n\t<li>The game uses $3N-1$ integer cards and $N-1$ operator cards.\r\n\t<ul>\r\n\t\t<li>An integer card has a two digit non negative integer written on it. The number written on the card may have a leading zero.<\/li>\r\n\t\t<li>An operator card has one of the four following operators, $+$, $-$, $\\times$, and $\\div$.<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n\t<li>For an integer $v$, greater than or equal to $1$ and less than or equal to $N$, place an integer card $A_v$ on the left of vertex $v$. Place an integer card $B_v$ on the right.<\/li>\r\n\t<li>For an integer $e$, greater than or equal to $1$ and less than or equal to $N-1$, place an operator card $P_e$ on the left of edge $e$. Place an integer card $C_e$ on the right.<\/li>\r\n\t<li>The game begins once all cards are placed down. As the game progresses, the following types of events occur $Q$ times.\r\n\t<ul>\r\n\t\t<li>Question: Given two vertices $x$ and $y$, you must calculate the result of the expression which is formed by arranging the cards on the path from vertex $x$ to vertex $y$.<\/li>\r\n\t\t<li>Change $A_x$: Given a vertex $x$ and an integer $y$, you must change the card on the left of vertex $x$ to an integer card with $y$ written on it.<\/li>\r\n\t\t<li>Change $B_x$: Given a vertex $x$ and an integer $y$, you must change the card on the right of vertex $x$ to an integer card with $y$ written on it.<\/li>\r\n\t\t<li>Change $P_x$: Given an edge $x$ and an operator $y$, you must change the card on the left of edge $x$ to an operator card with $y$ written on it.<\/li>\r\n\t\t<li>Change $C_x$: Given an edge $x$ and an integer $y$, you must change the card on the right of edge $x$ to an integer card with $y$ written on it.<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n\t<li>Beware of the following when answering a question.\r\n\t<ul>\r\n\t\t<li>Calculations are performed from the left ignoring the precedence of operators.<\/li>\r\n\t\t<li>The cards must be arranged starting from the one closest to the starting vertex\/edge. In addition, the card on the left of a vertex or an edge must come before the one on the right.&nbsp;For example, let the path be vertex $x$ &rarr; edge $a$ &rarr; vertex $b$ &rarr; edge $c$ &rarr; vertex $y$. In this case, the cards must be arranged in the order $A_x$, $B_x$, $P_a$, $C_a$, $A_b$, $B_b$, $P_c$, $C_c$, $A_y$, $B_y$.<\/li>\r\n\t\t<li>Where multiple integer cards are placed in a row, the integers must be concatenated and interpreted as a single number. For example, if the cards arranged are $12$, $57$, $+$, $12$, $03$, $17$, the result of the calculation is $12\\, 57+12\\, 03\\, 17=121\\, 374$.<\/li>\r\n\t\t<li>$x\\div 0$ is considered $0$.<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n<\/ul>\r\n\r\n<p>As an example, assume the cards on the path starting from vertex $1$ and ending at vertex $4$ are lined up from the following tree.<\/p>\r\n\r\n<p><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/c04c8167-5f9e-4a33-b771-8cd4e28ba915\/-\/preview\/\" style=\"width: 350px; max-width: 100%\" \/><\/p>\r\n\r\n<p>If you calculate the result after arranging all the cards, you get $07\\,23 + 27\\,06\\,24 - 35\\,13\\,26 = -79\\,979$.<\/p>\r\n\r\n<p>Hibee has played this game so much that now he can answer all questions correctly every time he plays. To prove this to Byehee, Hibee has decided to write a program which calculates and returns the answer of each question when given the game&#39;s progress.<\/p>\r\n","input":"<p>The first line of input contains two space-separated integers $N$ and $Q$, denoting the number of vertices the tree has, and the number of rounds of events played, respectively. $(1\\le N,Q\\le 500\\, 000)$<\/p>\r\n\r\n<p>The $i$-th of the following $N$ lines of input, starting from the second line, contains two space-separated integers $A_i$ and $B_i$, denoting the values written on the two integer cards placed next to vertex $i$.<\/p>\r\n\r\n<p>The $i$-th of the next $N-1$ lines, starting from the $N+2$-th line, contains the two vertices connected by edge $i$, the operator card $P_i$, and the integer card $C_i$, placed next to the edge. There is a space separating two values.<\/p>\r\n\r\n<p>Each of the following $Q$ lines contains a character $t$, denoting the type of event and two integers $x$ and $y$, which describe the event. There is a space separating the three values.<\/p>\r\n\r\n<ul>\r\n\t<li>$t=$ <span style=\"color:#e74c3c;\"><code>?<\/code><\/span>: Denotes a question event. Here, $x$ and $y$ satisfy $1 \\le x, y \\le N$.<\/li>\r\n\t<li>$t=$ <span style=\"color:#e74c3c;\"><code>A<\/code><\/span>: Denotes a change $A_x$ event. Here, $x$ and $y$ satisfy $1 \\le x \\le N;$ $00 \\le y \\le 99$.<\/li>\r\n\t<li>$t=$ <span style=\"color:#e74c3c;\"><code>B<\/code><\/span>: Denotes a change $B_x$ event. Here, $x$ and $y$ satisfy $1 \\le x \\le N;$ $00 \\le y \\le 99$.<\/li>\r\n\t<li>$t=$ <span style=\"color:#e74c3c;\"><code>P<\/code><\/span>: Denotes a change $P_x$ event. Here, $x$ is an integer which satisfies $1 \\le x \\le N-1$, and $y$ is one of $+$, $-$, $\\times$, $\\div$.<\/li>\r\n\t<li>$t=$ <span style=\"color:#e74c3c;\"><code>C<\/code><\/span>: Denotes a change $C_x$ event. Here, $x$ and $y$ are integers which satisfy $1 \\le x \\le N-1;$ $00 \\le y \\le 99$.<\/li>\r\n<\/ul>\r\n\r\n<p>$+$, $-$, $\\times$, $\\div$ are given as the characters <span style=\"color:#e74c3c;\"><code>+<\/code><\/span>, <span style=\"color:#e74c3c;\"><code>-<\/code><\/span>, <span style=\"color:#e74c3c;\"><code>*<\/code><\/span>, <span style=\"color:#e74c3c;\"><code>\/<\/code><\/span>, repsectively.<\/p>\r\n","output":"<p>For each question event, if the answer as a simplified fraction is $p\/q$, print the integer $r$, greater than or equal to $0$ and less than $1\\, 208\\, 017$, which satisfies $qr\\equiv p\\pmod{1\\, 208\\, 017}$. It can be proven that a unique integer always exists for each question event under the constraints of the problem.<\/p>\r\n\r\n<p>$1\\, 208\\, 017$ is prime.<\/p>\r\n","hint":"","original":"0","html_title":"0","problem_lang_tcode":"English","sample_explain_1":"<p>The first question event asks you to arrange the cards on the path starting from vertex $1$ and ending at vertex $4$. This results in $07\\, 23+27\\, 06\\, 24-35\\, 13\\, 26$ which is $-79\\, 277$. Here, $1\\cdot 1\\, 128\\, 038\\equiv -79\\, 979\\pmod{1\\, 208\\, 017}$. Thus, $1\\, 128\\, 038$ is the output.<\/p>\r\n\r\n<p>Then, $4$ change card events occur.<\/p>\r\n\r\n<p>The next question event asks you to arrange the cards on the path starting from vertex $2$ and ending at vertex $1$. This results in $27\\, 63\\div 61\\, 92\\, 09\\times 14\\, 06\\, 24+27\\, 87\\, 23$ which is $\\displaystyle \\frac{19\\, 219\\, 592\\, 691}{68\\, 801}$. Here, $68\\, 801\\cdot 975\\, 864\\equiv 19\\, 219\\, 592\\, 691\\pmod{1\\, 208\\, 017}$. Thus, $975\\, 864$ is the output.<\/p>\r\n"}]

출처