시간 제한메모리 제한제출정답맞힌 사람정답 비율
2 초 1024 MB59373572.917%

문제

$N + M$개의 게이트로 구성된 회로가 있다. 게이트들은 $0$부터 $N + M - 1$까지 번호가 붙어 있다. 게이트 $0$부터 $N - 1$까지는 임계 게이트들이고, 게이트 $N$부터 $N + M - 1$까지는 소스 게이트들이다.

게이트 $0$을 제외한 각 게이트의 출력은 하나이고 정확히 하나의 임계 게이트의 입력으로 연결된다. 좀더 구체적으로, 각 게이트 $i$의 ($1 \le i \le N + M - 1$) 출력은 게이트 $P[i]$의 입력이다. ($0 \le P[i] \le N-1$) 중요하게, $P[i] \lt i$가 항상 성립한다. 또, $P[0] = -1$이다. 즉, 게이트 $0$의 출력은 다른 어떤 게이트의 입력으로도 연결되지 않는다. 모든 임계 게이트는 하나 이상의 입력을 가진다. 모든 소스 게이트는 입력이 없다.

각 게이트는 $0$ 혹은 $1$의 값이 될 수 있는 상태를 가진다. 게이트의 출력은 그 게이트의 상태와 같다. 소스 게이트들의 상태는 입력 배열 $A$로 (배열 크기 $M$) 주어진다. 즉, 각 $j$에 대해 ($0 \le j \le M - 1$), $A[j]$의 값이 게이트 $N + j$의 상태이다.

각 임계 게이트의 상태는 해당 게이트의 입력에 따라 다음과 같이 결정된다. 각 임계 게이트에는 임계치를 결정하는 파라미터가 정해져 있다. $c$개의 입력을 가진 임계 게이트의 파라미터는 $1$ 이상 $c$ 이하의 정수이다. 파라미터가 $p$인 임계 게이트의 상태는, 입력 중 $p$개 이상이 $1$인 경우 $1$이고, 그렇지 않은 경우 $0$이다.

예를 들어, 아래 그림처럼 $N = 3$개의 임계 게이트와 $M = 4$개의 소스 게이트가 있는 회로가 있다고 하자. 게이트 $0$의 입력은 게이트 $1$과 $6$(의 출력)이고, 게이트 $1$의 입력은 게이트 $2$, $4$, $5$이며, 게이트 $2$의 입력은 게이트 $3$이다.

이 회로에서 게이트 $3$과 $5$의 상태는 $1$이고 게이트 $4$와 $6$의 상태는 $0$이라고 하자. 게이트 $2$, $1$, $0$의 파라미터는 각각 $1$, $2$, $2$라고 하자. 이 경우, 게이트 $2$의 상태는 $1$, 게이트 $1$의 상태는 $1$, 게이트 $0$의 상태는 $0$이 된다. 위의 상황은 아래 그림에 표시되어 있다. 게이트의 상태가 $1$인 것들이 검은 색으로 표시되어 있다.

소스 게이트들의 상태는 $Q$번 업데이트된다. 각 업데이트는 두 정수 $L$, $R$로 ($N \le L \le R \le N + M - 1$) 표현된다. 업데이트의 의미는 번호가 $L$부터 $R$까지인 모든 소스 게이트의 상태를 뒤집는 것이다. 뒤집는다는 것의 의미는 $0$을 $1$로, $1$을 $0$으로 바꾸는 것이다. 업데이트에 의해 변경된 게이트들의 상태는 이후의 업데이트에 영향을 받지 않는 한 유지된다.

초기 상태를 입력 받고, 각 업데이트 이후에 게이트 $0$의 상태가 $1$이 되도록 만들 수 있는 임계 게이트 파라미터 설정 방법의 경우의 수를 계산하는 프로그램을 작성하라. 두 파라미터 설정 방법이 다르다는 것은, 임계 게이트 중 하나라도 다른 파라미터 값을 가진다는 것으로 정의된다. 경우의 수 값이 매우 클 수 있으므로 그 값을 $1\,000\,002\,022$으로 나눈 나머지를 결과로 제시해야 한다.

위의 예에서 게이트 $0$, $1$, $2$는 각각 $2$, $3$, $1$개의 입력이 있으므로, 가능한 파라미터 설정 방법은 $6$가지가 있다. 가능한 방법들 중 $2$가지에서 게이트 $0$의 상태는 $1$이 된다.

구현

다음 2개의 함수를 구현해야 한다.

void init(int N, int M, int[] P, int[] A)
  • $N$: 임계 게이트의 개수.
  • $M$: 소스 게이트의 개수.
  • $P$: 임계 게이트의 입력을 표현한 크기 $N + M$인 배열.
  • $A$: 소스 게이트의 초기 상태를 표현한 크기 $M$인 배열.
  • 이 함수는 모든 count_ways 호출 이전에 정확히 한번 호출된다.
int count_ways(int L, int R)
  • $L$, $R$: 업데이트에 의해 뒤집히는 소스 게이트들의 번호 범위.
  • 이 함수는 지정된 업데이트를 수행한 후, 게이트 $0$의 상태가 $1$이 되게 만드는 파라미터 설정 방법의 경우의 수를 $1\,000\,002\,022$로 나눈 나머지를 리턴해야 한다.
  • 이 함수는 정확히 $Q$번 호출된다.

예제

다음 호출들을 보자:

init(3, 4, [-1, 0, 1, 2, 1, 1, 0], [1, 0, 1, 0])

이 회로는 본문에서 설명한 것과 같다.

count_ways(3, 4)

게이트 $3$과 $4$를 뒤집는다. 즉, 게이트 $3$의 상태는 $0$이 되고 게이트 $4$의 상태는 $1$이 된다. 게이트 $0$의 상태가 $1$이 되게 하는 $2$가지 파라미터 설정이 아래 그림에 표현되어 있다.

설정 $1$ 설정 $2$

위의 방법 이외의 모든 다른 설정에서 게이트 $0$의 상태가 $0$이 된다. 따라서, 이 함수 호출은 $2$를 리턴해야 한다.

count_ways(4, 5)

게이트 $4$와 $5$를 뒤집는다. 모든 소스 게이트의 상태가 $0$이 되었다. 이 경우 파라미터 설정을 어떻게 해도 게이트 $0$의 상태는 $0$이다. 따라서, 이 함수 호출은 $0$을 리턴해야 한다.

count_ways(3, 6)

모든 소스 게이트의 상태가 $1$로 바뀐다. 이 경우 파라미터 설정을 어떻게 해도 게이트 $0$의 상태는 $1$이다. 따라서, 이 함수 호출은 $6$을 리턴해야 한다.

제한

  • $1 \le N, M \le 100\,000$
  • $1 \le Q \le 100\,000$
  • $P[0] = -1$
  • $0 \le P[i] \lt i$이고 $P[i] \le N - 1$ ($1 \le i \le N + M - 1$)
  • 각 임계 게이트는 최소 하나의 입력이 있다. (모든 $i$($0 \le i \le N - 1$)에 대해 최소 하나의 $x$($i \lt x \le N + M - 1$)가 있어서 $P[x] = i$이다.)
  • $0 \le A[j] \le 1$ ($0 \le j \le M - 1$)
  • $N \le L \le R \le N + M - 1$

서브태스크

번호배점제한
12

$N = 1$, $M \le 1000$, $Q \le 5$

27

$N, M \le 1000$, $Q \le 5$, 각 임계 게이트에는 정확히 $2$개의 입력이 있다.

39

$N, M \le 1000$, $Q \le 5$

44

$M = N + 1$, $M = 2^z$ (양의 정수 $z$), $P[i] = \lfloor\frac{i - 1}{2}\rfloor$ ($1 \le i \le N + M - 1$), $L = R$

512

$M = N + 1$, $M = 2^z$ (양의 정수 $z$), $P[i] = \lfloor\frac{i - 1}{2}\rfloor$ ($1 \le i \le N + M - 1$)

627

각 임계 게이트에는 정확히 $2$개의 입력이 있다.

728

$N, M \le 5000$

811

추가적인 제한이 없다.

[{"problem_id":"25441","problem_lang":"0","title":"\ub514\uc9c0\ud138 \ud68c\ub85c","description":"<p>$N + M$\uac1c\uc758 <strong>\uac8c\uc774\ud2b8<\/strong>\ub85c \uad6c\uc131\ub41c \ud68c\ub85c\uac00 \uc788\ub2e4. \uac8c\uc774\ud2b8\ub4e4\uc740 $0$\ubd80\ud130 $N + M - 1$\uae4c\uc9c0 \ubc88\ud638\uac00 \ubd99\uc5b4 \uc788\ub2e4. \uac8c\uc774\ud2b8 $0$\ubd80\ud130 $N - 1$\uae4c\uc9c0\ub294 <strong>\uc784\uacc4 \uac8c\uc774\ud2b8<\/strong>\ub4e4\uc774\uace0, \uac8c\uc774\ud2b8 $N$\ubd80\ud130 $N + M - 1$\uae4c\uc9c0\ub294 <strong>\uc18c\uc2a4 \uac8c\uc774\ud2b8<\/strong>\ub4e4\uc774\ub2e4.<\/p>\r\n\r\n<p>\uac8c\uc774\ud2b8 $0$\uc744 \uc81c\uc678\ud55c \uac01 \uac8c\uc774\ud2b8\uc758 \ucd9c\ub825\uc740 \ud558\ub098\uc774\uace0 \uc815\ud655\ud788 \ud558\ub098\uc758 \uc784\uacc4 \uac8c\uc774\ud2b8\uc758 <strong>\uc785\ub825<\/strong>\uc73c\ub85c \uc5f0\uacb0\ub41c\ub2e4. \uc880\ub354 \uad6c\uccb4\uc801\uc73c\ub85c, \uac01 \uac8c\uc774\ud2b8 $i$\uc758 ($1 \\le i \\le N + M - 1$) \ucd9c\ub825\uc740 \uac8c\uc774\ud2b8 $P[i]$\uc758 \uc785\ub825\uc774\ub2e4. ($0 \\le P[i] \\le N-1$) \uc911\uc694\ud558\uac8c, $P[i] \\lt i$\uac00 \ud56d\uc0c1 \uc131\ub9bd\ud55c\ub2e4. \ub610, $P[0] = -1$\uc774\ub2e4. \uc989, \uac8c\uc774\ud2b8 $0$\uc758 \ucd9c\ub825\uc740 \ub2e4\ub978 \uc5b4\ub5a4 \uac8c\uc774\ud2b8\uc758 \uc785\ub825\uc73c\ub85c\ub3c4 \uc5f0\uacb0\ub418\uc9c0 \uc54a\ub294\ub2e4. \ubaa8\ub4e0 \uc784\uacc4 \uac8c\uc774\ud2b8\ub294 \ud558\ub098 \uc774\uc0c1\uc758 \uc785\ub825\uc744 \uac00\uc9c4\ub2e4. \ubaa8\ub4e0 \uc18c\uc2a4 \uac8c\uc774\ud2b8\ub294 \uc785\ub825\uc774 \uc5c6\ub2e4.<\/p>\r\n\r\n<p>\uac01 \uac8c\uc774\ud2b8\ub294 $0$ \ud639\uc740 $1$\uc758 \uac12\uc774 \ub420 \uc218 \uc788\ub294 <strong>\uc0c1\ud0dc<\/strong>\ub97c \uac00\uc9c4\ub2e4. \uac8c\uc774\ud2b8\uc758 \ucd9c\ub825\uc740 \uadf8 \uac8c\uc774\ud2b8\uc758 \uc0c1\ud0dc\uc640 \uac19\ub2e4. \uc18c\uc2a4 \uac8c\uc774\ud2b8\ub4e4\uc758 \uc0c1\ud0dc\ub294 \uc785\ub825 \ubc30\uc5f4 $A$\ub85c (\ubc30\uc5f4 \ud06c\uae30 $M$) \uc8fc\uc5b4\uc9c4\ub2e4. \uc989, \uac01 $j$\uc5d0 \ub300\ud574 ($0 \\le j \\le M - 1$), $A[j]$\uc758 \uac12\uc774 \uac8c\uc774\ud2b8 $N + j$\uc758 \uc0c1\ud0dc\uc774\ub2e4.<\/p>\r\n\r\n<p>\uac01 \uc784\uacc4 \uac8c\uc774\ud2b8\uc758 \uc0c1\ud0dc\ub294 \ud574\ub2f9 \uac8c\uc774\ud2b8\uc758 \uc785\ub825\uc5d0 \ub530\ub77c \ub2e4\uc74c\uacfc \uac19\uc774 \uacb0\uc815\ub41c\ub2e4. \uac01 \uc784\uacc4 \uac8c\uc774\ud2b8\uc5d0\ub294 \uc784\uacc4\uce58\ub97c \uacb0\uc815\ud558\ub294 <strong>\ud30c\ub77c\ubbf8\ud130<\/strong>\uac00 \uc815\ud574\uc838 \uc788\ub2e4. $c$\uac1c\uc758 \uc785\ub825\uc744 \uac00\uc9c4 \uc784\uacc4 \uac8c\uc774\ud2b8\uc758 \ud30c\ub77c\ubbf8\ud130\ub294 $1$ \uc774\uc0c1 $c$ \uc774\ud558\uc758 \uc815\uc218\uc774\ub2e4. \ud30c\ub77c\ubbf8\ud130\uac00 $p$\uc778 \uc784\uacc4 \uac8c\uc774\ud2b8\uc758 \uc0c1\ud0dc\ub294, \uc785\ub825 \uc911 $p$\uac1c \uc774\uc0c1\uc774 $1$\uc778 \uacbd\uc6b0 $1$\uc774\uace0, \uadf8\ub807\uc9c0 \uc54a\uc740 \uacbd\uc6b0 $0$\uc774\ub2e4.<\/p>\r\n\r\n<p>\uc608\ub97c \ub4e4\uc5b4, \uc544\ub798 \uadf8\ub9bc\ucc98\ub7fc $N = 3$\uac1c\uc758 \uc784\uacc4 \uac8c\uc774\ud2b8\uc640 $M = 4$\uac1c\uc758 \uc18c\uc2a4 \uac8c\uc774\ud2b8\uac00 \uc788\ub294 \ud68c\ub85c\uac00 \uc788\ub2e4\uace0 \ud558\uc790. \uac8c\uc774\ud2b8 $0$\uc758 \uc785\ub825\uc740 \uac8c\uc774\ud2b8 $1$\uacfc $6$(\uc758 \ucd9c\ub825)\uc774\uace0, \uac8c\uc774\ud2b8 $1$\uc758 \uc785\ub825\uc740 \uac8c\uc774\ud2b8 $2$, $4$, $5$\uc774\uba70, \uac8c\uc774\ud2b8 $2$\uc758 \uc785\ub825\uc740 \uac8c\uc774\ud2b8 $3$\uc774\ub2e4.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/0f2a915a-0fc1-4acf-972a-754de57bc3d0\/-\/preview\/\" style=\"width: 207px; height: 233px;\" \/><\/p>\r\n\r\n<p>\uc774 \ud68c\ub85c\uc5d0\uc11c \uac8c\uc774\ud2b8 $3$\uacfc $5$\uc758 \uc0c1\ud0dc\ub294 $1$\uc774\uace0 \uac8c\uc774\ud2b8 $4$\uc640 $6$\uc758 \uc0c1\ud0dc\ub294 $0$\uc774\ub77c\uace0 \ud558\uc790. \uac8c\uc774\ud2b8 $2$, $1$, $0$\uc758 \ud30c\ub77c\ubbf8\ud130\ub294 \uac01\uac01 $1$, $2$, $2$\ub77c\uace0 \ud558\uc790. \uc774 \uacbd\uc6b0, \uac8c\uc774\ud2b8 $2$\uc758 \uc0c1\ud0dc\ub294 $1$, \uac8c\uc774\ud2b8 $1$\uc758 \uc0c1\ud0dc\ub294 $1$, \uac8c\uc774\ud2b8 $0$\uc758 \uc0c1\ud0dc\ub294 $0$\uc774 \ub41c\ub2e4. \uc704\uc758 \uc0c1\ud669\uc740 \uc544\ub798 \uadf8\ub9bc\uc5d0 \ud45c\uc2dc\ub418\uc5b4 \uc788\ub2e4. \uac8c\uc774\ud2b8\uc758 \uc0c1\ud0dc\uac00 $1$\uc778 \uac83\ub4e4\uc774 \uac80\uc740 \uc0c9\uc73c\ub85c \ud45c\uc2dc\ub418\uc5b4 \uc788\ub2e4.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/e91bcdbb-3adb-4850-aa80-de0fe9eed074\/-\/preview\/\" style=\"width: 207px; height: 233px;\" \/><\/p>\r\n\r\n<p>\uc18c\uc2a4 \uac8c\uc774\ud2b8\ub4e4\uc758 \uc0c1\ud0dc\ub294 $Q$\ubc88 \uc5c5\ub370\uc774\ud2b8\ub41c\ub2e4. \uac01 \uc5c5\ub370\uc774\ud2b8\ub294 \ub450 \uc815\uc218 $L$, $R$\ub85c ($N \\le L \\le R \\le N + M - 1$) \ud45c\ud604\ub41c\ub2e4. \uc5c5\ub370\uc774\ud2b8\uc758 \uc758\ubbf8\ub294 \ubc88\ud638\uac00 $L$\ubd80\ud130 $R$\uae4c\uc9c0\uc778 \ubaa8\ub4e0 \uc18c\uc2a4 \uac8c\uc774\ud2b8\uc758 \uc0c1\ud0dc\ub97c \ub4a4\uc9d1\ub294 \uac83\uc774\ub2e4. \ub4a4\uc9d1\ub294\ub2e4\ub294 \uac83\uc758 \uc758\ubbf8\ub294 $0$\uc744 $1$\ub85c, $1$\uc744 $0$\uc73c\ub85c \ubc14\uafb8\ub294 \uac83\uc774\ub2e4. \uc5c5\ub370\uc774\ud2b8\uc5d0 \uc758\ud574 \ubcc0\uacbd\ub41c \uac8c\uc774\ud2b8\ub4e4\uc758 \uc0c1\ud0dc\ub294 \uc774\ud6c4\uc758 \uc5c5\ub370\uc774\ud2b8\uc5d0 \uc601\ud5a5\uc744 \ubc1b\uc9c0 \uc54a\ub294 \ud55c \uc720\uc9c0\ub41c\ub2e4.<\/p>\r\n\r\n<p>\ucd08\uae30 \uc0c1\ud0dc\ub97c \uc785\ub825 \ubc1b\uace0, \uac01 \uc5c5\ub370\uc774\ud2b8 \uc774\ud6c4\uc5d0 \uac8c\uc774\ud2b8 $0$\uc758 \uc0c1\ud0dc\uac00 $1$\uc774 \ub418\ub3c4\ub85d \ub9cc\ub4e4 \uc218 \uc788\ub294 \uc784\uacc4 \uac8c\uc774\ud2b8 \ud30c\ub77c\ubbf8\ud130 \uc124\uc815 \ubc29\ubc95\uc758 \uacbd\uc6b0\uc758 \uc218\ub97c \uacc4\uc0b0\ud558\ub294 \ud504\ub85c\uadf8\ub7a8\uc744 \uc791\uc131\ud558\ub77c. \ub450 \ud30c\ub77c\ubbf8\ud130 \uc124\uc815 \ubc29\ubc95\uc774 \ub2e4\ub974\ub2e4\ub294 \uac83\uc740, \uc784\uacc4 \uac8c\uc774\ud2b8 \uc911 \ud558\ub098\ub77c\ub3c4 \ub2e4\ub978 \ud30c\ub77c\ubbf8\ud130 \uac12\uc744 \uac00\uc9c4\ub2e4\ub294 \uac83\uc73c\ub85c \uc815\uc758\ub41c\ub2e4. \uacbd\uc6b0\uc758 \uc218 \uac12\uc774 \ub9e4\uc6b0 \ud074 \uc218 \uc788\uc73c\ubbc0\ub85c \uadf8 \uac12\uc744 $1\\,000\\,002\\,022$\uc73c\ub85c \ub098\ub208 \ub098\uba38\uc9c0\ub97c \uacb0\uacfc\ub85c \uc81c\uc2dc\ud574\uc57c \ud55c\ub2e4.<\/p>\r\n\r\n<p>\uc704\uc758 \uc608\uc5d0\uc11c \uac8c\uc774\ud2b8 $0$, $1$, $2$\ub294 \uac01\uac01 $2$, $3$, $1$\uac1c\uc758 \uc785\ub825\uc774 \uc788\uc73c\ubbc0\ub85c, \uac00\ub2a5\ud55c \ud30c\ub77c\ubbf8\ud130 \uc124\uc815 \ubc29\ubc95\uc740 $6$\uac00\uc9c0\uac00 \uc788\ub2e4. \uac00\ub2a5\ud55c \ubc29\ubc95\ub4e4 \uc911 $2$\uac00\uc9c0\uc5d0\uc11c \uac8c\uc774\ud2b8 $0$\uc758 \uc0c1\ud0dc\ub294 $1$\uc774 \ub41c\ub2e4.<\/p>\r\n","input":"","output":"","hint":"","original":"0","html_title":"0","problem_lang_tcode":"Korean","limit":"<ul>\r\n\t<li>$1 \\le N, M \\le 100\\,000$<\/li>\r\n\t<li>$1 \\le Q \\le 100\\,000$<\/li>\r\n\t<li>$P[0] = -1$<\/li>\r\n\t<li>$0 \\le P[i] \\lt i$\uc774\uace0 $P[i] \\le N - 1$ ($1 \\le i \\le N + M - 1$)<\/li>\r\n\t<li>\uac01 \uc784\uacc4 \uac8c\uc774\ud2b8\ub294 \ucd5c\uc18c \ud558\ub098\uc758 \uc785\ub825\uc774 \uc788\ub2e4. (\ubaa8\ub4e0 $i$($0 \\le i \\le N - 1$)\uc5d0 \ub300\ud574 \ucd5c\uc18c \ud558\ub098\uc758 $x$($i \\lt x \\le N + M - 1$)\uac00 \uc788\uc5b4\uc11c $P[x] = i$\uc774\ub2e4.)<\/li>\r\n\t<li>$0 \\le A[j] \\le 1$ ($0 \\le j \\le M - 1$)<\/li>\r\n\t<li>$N \\le L \\le R \\le N + M - 1$<\/li>\r\n<\/ul>\r\n","subtask1":"<p>$N = 1$, $M \\le 1000$, $Q \\le 5$<\/p>\r\n","subtask2":"<p>$N, M \\le 1000$, $Q \\le 5$, \uac01 \uc784\uacc4 \uac8c\uc774\ud2b8\uc5d0\ub294 \uc815\ud655\ud788 $2$\uac1c\uc758 \uc785\ub825\uc774 \uc788\ub2e4.<\/p>\r\n","subtask3":"<p>$N, M \\le 1000$, $Q \\le 5$<\/p>\r\n","subtask4":"<p>$M = N + 1$, $M = 2^z$ (\uc591\uc758 \uc815\uc218 $z$), $P[i] = \\lfloor\\frac{i - 1}{2}\\rfloor$ ($1 \\le i \\le N + M - 1$), $L = R$<\/p>\r\n","subtask5":"<p>$M = N + 1$, $M = 2^z$ (\uc591\uc758 \uc815\uc218 $z$), $P[i] = \\lfloor\\frac{i - 1}{2}\\rfloor$ ($1 \\le i \\le N + M - 1$)<\/p>\r\n","subtask6":"<p>\uac01 \uc784\uacc4 \uac8c\uc774\ud2b8\uc5d0\ub294 \uc815\ud655\ud788 $2$\uac1c\uc758 \uc785\ub825\uc774 \uc788\ub2e4.<\/p>\r\n","subtask7":"<p>$N, M \\le 5000$<\/p>\r\n","subtask8":"<p>\ucd94\uac00\uc801\uc778 \uc81c\ud55c\uc774 \uc5c6\ub2e4.<\/p>\r\n","custom_implementation":"<p>\ub2e4\uc74c 2\uac1c\uc758 \ud568\uc218\ub97c \uad6c\ud604\ud574\uc57c \ud55c\ub2e4.<\/p>\r\n\r\n<pre>\r\n<code>void init(int N, int M, int[] P, int[] A)\r\n<\/code><\/pre>\r\n\r\n<ul>\r\n\t<li>$N$: \uc784\uacc4 \uac8c\uc774\ud2b8\uc758 \uac1c\uc218.<\/li>\r\n\t<li>$M$: \uc18c\uc2a4 \uac8c\uc774\ud2b8\uc758 \uac1c\uc218.<\/li>\r\n\t<li>$P$: \uc784\uacc4 \uac8c\uc774\ud2b8\uc758 \uc785\ub825\uc744 \ud45c\ud604\ud55c \ud06c\uae30 $N + M$\uc778 \ubc30\uc5f4.<\/li>\r\n\t<li>$A$: \uc18c\uc2a4 \uac8c\uc774\ud2b8\uc758 \ucd08\uae30 \uc0c1\ud0dc\ub97c \ud45c\ud604\ud55c \ud06c\uae30 $M$\uc778 \ubc30\uc5f4.<\/li>\r\n\t<li>\uc774 \ud568\uc218\ub294 \ubaa8\ub4e0 <code>count_ways<\/code> \ud638\ucd9c \uc774\uc804\uc5d0 \uc815\ud655\ud788 \ud55c\ubc88 \ud638\ucd9c\ub41c\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<pre>\r\n<code>int count_ways(int L, int R)\r\n<\/code><\/pre>\r\n\r\n<ul>\r\n\t<li>$L$, $R$: \uc5c5\ub370\uc774\ud2b8\uc5d0 \uc758\ud574 \ub4a4\uc9d1\ud788\ub294 \uc18c\uc2a4 \uac8c\uc774\ud2b8\ub4e4\uc758 \ubc88\ud638 \ubc94\uc704.<\/li>\r\n\t<li>\uc774 \ud568\uc218\ub294 \uc9c0\uc815\ub41c \uc5c5\ub370\uc774\ud2b8\ub97c \uc218\ud589\ud55c \ud6c4, \uac8c\uc774\ud2b8 $0$\uc758 \uc0c1\ud0dc\uac00 $1$\uc774 \ub418\uac8c \ub9cc\ub4dc\ub294 \ud30c\ub77c\ubbf8\ud130 \uc124\uc815 \ubc29\ubc95\uc758 \uacbd\uc6b0\uc758 \uc218\ub97c $1\\,000\\,002\\,022$\ub85c \ub098\ub208 \ub098\uba38\uc9c0\ub97c \ub9ac\ud134\ud574\uc57c \ud55c\ub2e4.<\/li>\r\n\t<li>\uc774 \ud568\uc218\ub294 \uc815\ud655\ud788 $Q$\ubc88 \ud638\ucd9c\ub41c\ub2e4.<\/li>\r\n<\/ul>\r\n","custom_example":"<p>\ub2e4\uc74c \ud638\ucd9c\ub4e4\uc744 \ubcf4\uc790:<\/p>\r\n\r\n<pre>\r\n<code>init(3, 4, [-1, 0, 1, 2, 1, 1, 0], [1, 0, 1, 0])\r\n<\/code><\/pre>\r\n\r\n<p>\uc774 \ud68c\ub85c\ub294 \ubcf8\ubb38\uc5d0\uc11c \uc124\uba85\ud55c \uac83\uacfc \uac19\ub2e4.<\/p>\r\n\r\n<pre>\r\n<code>count_ways(3, 4)\r\n<\/code><\/pre>\r\n\r\n<p>\uac8c\uc774\ud2b8 $3$\uacfc $4$\ub97c \ub4a4\uc9d1\ub294\ub2e4. \uc989, \uac8c\uc774\ud2b8 $3$\uc758 \uc0c1\ud0dc\ub294 $0$\uc774 \ub418\uace0 \uac8c\uc774\ud2b8 $4$\uc758 \uc0c1\ud0dc\ub294 $1$\uc774 \ub41c\ub2e4. \uac8c\uc774\ud2b8 $0$\uc758 \uc0c1\ud0dc\uac00 $1$\uc774 \ub418\uac8c \ud558\ub294 $2$\uac00\uc9c0 \ud30c\ub77c\ubbf8\ud130 \uc124\uc815\uc774 \uc544\ub798 \uadf8\ub9bc\uc5d0 \ud45c\ud604\ub418\uc5b4 \uc788\ub2e4.<\/p>\r\n\r\n<table class=\"table table-bordered th-center td-center\">\r\n\t<thead>\r\n\t\t<tr>\r\n\t\t\t<th>\uc124\uc815 $1$<\/th>\r\n\t\t\t<th>\uc124\uc815 $2$<\/th>\r\n\t\t<\/tr>\r\n\t<\/thead>\r\n\t<tbody>\r\n\t\t<tr>\r\n\t\t\t<td><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/be0bdcec-39a7-4100-91bc-981367c75b2a\/-\/crop\/364x422\/0,0\/-\/preview\/\" style=\"width: 182px; height: 211px;\" \/><\/td>\r\n\t\t\t<td><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/be0bdcec-39a7-4100-91bc-981367c75b2a\/-\/crop\/364x422\/434,0\/-\/preview\/\" style=\"width: 182px; height: 211px;\" \/><\/td>\r\n\t\t<\/tr>\r\n\t<\/tbody>\r\n<\/table>\r\n\r\n<p>\uc704\uc758 \ubc29\ubc95 \uc774\uc678\uc758 \ubaa8\ub4e0 \ub2e4\ub978 \uc124\uc815\uc5d0\uc11c \uac8c\uc774\ud2b8 $0$\uc758 \uc0c1\ud0dc\uac00 $0$\uc774 \ub41c\ub2e4. \ub530\ub77c\uc11c, \uc774 \ud568\uc218 \ud638\ucd9c\uc740 $2$\ub97c \ub9ac\ud134\ud574\uc57c \ud55c\ub2e4.<\/p>\r\n\r\n<pre>\r\n<code>count_ways(4, 5)\r\n<\/code><\/pre>\r\n\r\n<p>\uac8c\uc774\ud2b8 $4$\uc640 $5$\ub97c \ub4a4\uc9d1\ub294\ub2e4. \ubaa8\ub4e0 \uc18c\uc2a4 \uac8c\uc774\ud2b8\uc758 \uc0c1\ud0dc\uac00 $0$\uc774 \ub418\uc5c8\ub2e4. \uc774 \uacbd\uc6b0 \ud30c\ub77c\ubbf8\ud130 \uc124\uc815\uc744 \uc5b4\ub5bb\uac8c \ud574\ub3c4 \uac8c\uc774\ud2b8 $0$\uc758 \uc0c1\ud0dc\ub294 $0$\uc774\ub2e4. \ub530\ub77c\uc11c, \uc774 \ud568\uc218 \ud638\ucd9c\uc740 $0$\uc744 \ub9ac\ud134\ud574\uc57c \ud55c\ub2e4.<\/p>\r\n\r\n<pre>\r\n<code>count_ways(3, 6)\r\n<\/code><\/pre>\r\n\r\n<p>\ubaa8\ub4e0 \uc18c\uc2a4 \uac8c\uc774\ud2b8\uc758 \uc0c1\ud0dc\uac00 $1$\ub85c \ubc14\ub010\ub2e4. \uc774 \uacbd\uc6b0 \ud30c\ub77c\ubbf8\ud130 \uc124\uc815\uc744 \uc5b4\ub5bb\uac8c \ud574\ub3c4 \uac8c\uc774\ud2b8 $0$\uc758 \uc0c1\ud0dc\ub294 $1$\uc774\ub2e4. \ub530\ub77c\uc11c, \uc774 \ud568\uc218 \ud638\ucd9c\uc740 $6$\uc744 \ub9ac\ud134\ud574\uc57c \ud55c\ub2e4.<\/p>\r\n","custom_samplegrader":"<p>\uc0d8\ud50c \uadf8\ub808\uc774\ub354\ub294 \ub2e4\uc74c\uc758 \uc591\uc2dd\uc73c\ub85c \uc785\ub825\uc744 \ubc1b\ub294\ub2e4:<\/p>\r\n\r\n<ul>\r\n\t<li>line $1$: $N \\, M \\, Q$<\/li>\r\n\t<li>line $2$: $P[0] \\, P[1] \\, \\ldots \\, P[N + M - 1]$<\/li>\r\n\t<li>line $3$: $A[0] \\, A[1] \\, \\ldots \\, A[M - 1]$<\/li>\r\n\t<li>line $4 + k$ ($0 \\le k \\le Q - 1$): \uc5c5\ub370\uc774\ud2b8$k$\uc758 $L$\uacfc $R$<\/li>\r\n<\/ul>\r\n\r\n<p>\uc0d8\ud50c \uadf8\ub808\uc774\ub354\ub294 \ub2e4\uc74c\uc758 \ucd9c\ub825\uc744 \uc0dd\uc131\ud55c\ub2e4:<\/p>\r\n\r\n<ul>\r\n\t<li>line $1 + k$ ($0 \\le k \\le Q - 1$): \uc5c5\ub370\uc774\ud2b8 $k$\uc5d0 \ub300\ud55c <code>count_ways<\/code>\uc758 \ub9ac\ud134 \uac12<\/li>\r\n<\/ul>\r\n","custom_attachment":"<ul>\r\n\t<li><a href=\"https:\/\/upload.acmicpc.net\/2ab00bd1-f7a5-42bc-9f09-56a5f1b81bae\/\">circuit.zip<\/a><\/li>\r\n<\/ul>\r\n"},{"problem_id":"25441","problem_lang":"1","title":"Digital Circuit","description":"<p>There is a circuit, which consists of $N + M$&nbsp;<strong>gates<\/strong>&nbsp;numbered from $0$ to $N + M - 1$. Gates $0$ to $N - 1$ are&nbsp;<strong>threshold gates<\/strong>, whereas gates $N$ to $N + M - 1$ are&nbsp;<strong>source gates<\/strong>.<\/p>\r\n\r\n<p>Each gate, except for gate $0$, is an&nbsp;<strong>input<\/strong>&nbsp;to exactly one threshold gate. Specifically, for each $i$ such that $1 \\le i \\le N + M - 1$, gate $i$ is an input to gate $P[i]$, where $0 \\le P[i] \\le N-1$. Importantly, we also have $P[i] \\lt i$. Moreover, we assume $P[0] = -1$. Each threshold gate has one or more inputs. Source gates do not have any inputs.<\/p>\r\n\r\n<p>Each gate has a&nbsp;<strong>state<\/strong>&nbsp;which is either $0$ or $1$. The initial states of the source gates are given by an array $A$ of $M$ integers. That is, for each $j$ such that $0 \\le j \\le M - 1$, the initial state of the source gate $N + j$ is $A[j]$.<\/p>\r\n\r\n<p>The state of each threshold gate depends on the states of its inputs and is determined as follows. First, each threshold gate is assigned a threshold&nbsp;<strong>parameter<\/strong>. The parameter assigned to a threshold gate with $c$ inputs must be an integer between $1$ and $c$ (inclusive). Then, the state of a threshold gate with parameter $p$ is $1$, if at least $p$ of its inputs have state $1$, and $0$ otherwise.<\/p>\r\n\r\n<p>For example, suppose there are $N = 3$ threshold gates and $M = 4$ source gates. The inputs to gate $0$ are gates $1$ and $6$, the inputs to gate $1$ are gates $2$, $4$, and $5$, and the only input to gate $2$ is gate $3$.<\/p>\r\n\r\n<p>This example is illustrated in the following picture.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/0f2a915a-0fc1-4acf-972a-754de57bc3d0\/-\/preview\/\" style=\"width: 207px; height: 233px;\" \/><\/p>\r\n\r\n<p>Suppose that source gates $3$ and $5$ have state $1$, while source gates $4$ and $6$ have state $0$. Assume we assign parameters $1$, $2$ and $2$ to threshold gates $2$, $1$ and $0$ respectively. In this case, gate $2$ has state $1$, gate $1$ has state $1$ and gate $0$ has state $0$. This assignment of parameter values and the states is illustrated in the following picture. Gates whose state is $1$ are marked in black.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/e91bcdbb-3adb-4850-aa80-de0fe9eed074\/-\/preview\/\" style=\"width: 207px; height: 233px;\" \/><\/p>\r\n\r\n<p>The states of the source gates will undergo $Q$ updates. Each update is described by two integers $L$ and $R$ ($N \\le L \\le R \\le N + M - 1$) and toggles the states of all source gates numbered between $L$ and $R$, inclusive. That is, for each $i$ such that $L \\le i \\le R$, source gate $i$ changes its state to $1$, if its state is $0$, or to $0$, if its state is $1$. The new state of each toggled gate remains unchanged until it is possibly toggled by one of the later updates.<\/p>\r\n\r\n<p>Your goal is to count, after each update, how many different assignments of parameters to threshold gates result in gate $0$ having state $1$. Two assignments are considered different if there exists at least one threshold gate that has a different value of its parameter in both assignments. As the number of ways can be large, you should compute it modulo $1\\,000\\,002\\,022$.<\/p>\r\n\r\n<p>Note that in the example above, there are $6$ different assignments of parameters to threshold gates, since gates $0$, $1$ and $2$ have $2$, $3$ and $1$ inputs respectively. In $2$ out of these $6$ assignments, gate $0$ has state $1$.<\/p>\r\n","input":"","output":"","hint":"","original":"1","html_title":"0","problem_lang_tcode":"English","limit":"<ul>\r\n\t<li>$1 \\le N, M \\le 100\\,000$<\/li>\r\n\t<li>$1 \\le Q \\le 100\\,000$<\/li>\r\n\t<li>$P[0] = -1$<\/li>\r\n\t<li>$0 \\le P[i] \\lt i$ and $P[i] \\le N - 1$ (for each $i$ such that $1 \\le i \\le N + M - 1$)<\/li>\r\n\t<li>Each threshold gate has at least one input (for each $i$ such that $0 \\le i \\le N - 1$ there exists an index $x$ such that $i \\lt x \\le N + M - 1$ and $P[x] = i$).<\/li>\r\n\t<li>$0 \\le A[j] \\le 1$ (for each $j$ such that $0 \\le j \\le M - 1$)<\/li>\r\n\t<li>$N \\le L \\le R \\le N + M - 1$<\/li>\r\n<\/ul>\r\n","subtask1":"<p>$N = 1$, $M \\le 1000$, $Q \\le 5$<\/p>\r\n","subtask2":"<p>$N, M \\le 1000$, $Q \\le 5$, each threshold gate has exactly two inputs.<\/p>\r\n","subtask3":"<p>$N, M \\le 1000$, $Q \\le 5$<\/p>\r\n","subtask4":"<p>$M = N + 1$, $M = 2^z$ (for some positive integer $z$), $P[i] = \\lfloor\\frac{i - 1}{2}\\rfloor$ (for each $i$ such that $1 \\le i \\le N + M - 1$), $L = R$<\/p>\r\n","subtask5":"<p>$M = N + 1$, $M = 2^z$ (for some positive integer $z$), $P[i] = \\lfloor\\frac{i - 1}{2}\\rfloor$ (for each $i$ such that $1 \\le i \\le N + M - 1$)<\/p>\r\n","subtask6":"<p>Each threshold gate has exactly two inputs.<\/p>\r\n","subtask7":"<p>$N, M \\le 5000$<\/p>\r\n","subtask8":"<p>No additional constraints.<\/p>\r\n","custom_implementation":"<p>Your task is to implement two procedures.<\/p>\r\n\r\n<pre>\r\n<code>void init(int N, int M, int[] P, int[] A)\r\n<\/code><\/pre>\r\n\r\n<ul>\r\n\t<li>$N$: the number of threshold gates.<\/li>\r\n\t<li>$M$: the number of source gates.<\/li>\r\n\t<li>$P$: an array of length $N + M$ describing the inputs to the threshold gates.<\/li>\r\n\t<li>$A$: an array of length $M$ describing the initial states of the source gates.<\/li>\r\n\t<li>This procedure is called exactly once, before any calls to <code>count_ways<\/code>.<\/li>\r\n<\/ul>\r\n\r\n<pre>\r\n<code>int count_ways(int L, int R)\r\n<\/code><\/pre>\r\n\r\n<ul>\r\n\t<li>$L$, $R$: the boundaries of the range of source gates, whose states are toggled.<\/li>\r\n\t<li>This procedure should first perform the specified update, and then return the number of ways, modulo $1;000;002;022$, of assigning parameters to the threshold gates, which result in gate $0$ having state $1$.<\/li>\r\n\t<li>This procedure is called exactly $Q$ times.<\/li>\r\n<\/ul>\r\n","custom_example":"<p>Consider the following sequence of calls:<\/p>\r\n\r\n<pre>\r\n<code>init(3, 4, [-1, 0, 1, 2, 1, 1, 0], [1, 0, 1, 0])\r\n<\/code><\/pre>\r\n\r\n<p>This example is illustrated in the task description above.<\/p>\r\n\r\n<pre>\r\n<code>count_ways(3, 4)\r\n<\/code><\/pre>\r\n\r\n<p>This toggles the states of gates $3$ and $4$, i.e. the state of gate $3$ becomes $0$, and the state of gate $4$ becomes $1$. Two ways of assigning the parameters which result in gate $0$ having state $1$ are illustrated in the pictures below.<\/p>\r\n\r\n<table class=\"table table-bordered th-center td-center\">\r\n\t<thead>\r\n\t\t<tr>\r\n\t\t\t<th>Way $1$<\/th>\r\n\t\t\t<th>Way $2$<\/th>\r\n\t\t<\/tr>\r\n\t<\/thead>\r\n\t<tbody>\r\n\t\t<tr>\r\n\t\t\t<td><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/be0bdcec-39a7-4100-91bc-981367c75b2a\/-\/crop\/364x422\/0,0\/-\/preview\/\" style=\"width: 182px; height: 211px;\" \/><\/td>\r\n\t\t\t<td><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/be0bdcec-39a7-4100-91bc-981367c75b2a\/-\/crop\/364x422\/434,0\/-\/preview\/\" style=\"width: 182px; height: 211px;\" \/><\/td>\r\n\t\t<\/tr>\r\n\t<\/tbody>\r\n<\/table>\r\n\r\n<p>In all other assignments of parameters, gate $0$ has state $0$. Thus, the procedure should return $2$.<\/p>\r\n\r\n<pre>\r\n<code>count_ways(4, 5)\r\n<\/code><\/pre>\r\n\r\n<p>This toggles the states of gates $4$ and $5$. As a result, all source gates have state $0$, and for any assignment of parameters, gate $0$ has state $0$. Thus, the procedure should return $0$.<\/p>\r\n\r\n<pre>\r\n<code>count_ways(3, 6)\r\n<\/code><\/pre>\r\n\r\n<p>This changes the states of all source gates to $1$. As a result, for any assignment of parameters, gate $0$ has state $1$. Thus, the procedure should return $6$.<\/p>\r\n","custom_samplegrader":"<p>The sample grader reads the input in the following format:<\/p>\r\n\r\n<ul>\r\n\t<li>line $1$: $N \\, M \\, Q$<\/li>\r\n\t<li>line $2$: $P[0] \\, P[1] \\, \\ldots \\, P[N + M - 1]$<\/li>\r\n\t<li>line $3$: $A[0] \\, A[1] \\, \\ldots \\, A[M - 1]$<\/li>\r\n\t<li>line $4 + k$ ($0 \\le k \\le Q - 1$): $L \\, R$ for update $k$<\/li>\r\n<\/ul>\r\n\r\n<p>The sample grader prints your answers in the following format:<\/p>\r\n\r\n<ul>\r\n\t<li>line $1 + k$ ($0 \\le k \\le Q - 1$): the return value of <code>count_ways<\/code> for update $k$<\/li>\r\n<\/ul>\r\n","custom_attachment":"<ul>\r\n\t<li><a href=\"https:\/\/upload.acmicpc.net\/2ab00bd1-f7a5-42bc-9f09-56a5f1b81bae\/\">circuit.zip<\/a><\/li>\r\n<\/ul>\r\n"}]

샘플 그레이더

샘플 그레이더는 다음의 양식으로 입력을 받는다:

  • line $1$: $N \, M \, Q$
  • line $2$: $P[0] \, P[1] \, \ldots \, P[N + M - 1]$
  • line $3$: $A[0] \, A[1] \, \ldots \, A[M - 1]$
  • line $4 + k$ ($0 \le k \le Q - 1$): 업데이트$k$의 $L$과 $R$

샘플 그레이더는 다음의 출력을 생성한다:

  • line $1 + k$ ($0 \le k \le Q - 1$): 업데이트 $k$에 대한 count_ways의 리턴 값

첨부

출처

Olympiad > International Olympiad in Informatics > IOI 2022 > Day 2 4번

  • 문제를 만든 사람: Prabowo Djonatan

제출할 수 있는 언어

C++17, C++20, C++17 (Clang), C++20 (Clang)

채점 및 기타 정보

  • 예제는 채점하지 않는다.
  • 이 문제의 채점 우선 순위는 2이다.