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

문제

W Bajtocji istnieje sieć jednokierunkowych autostrad łączących miasta z n województw. Województwa są ponumerowane od 1 do n. Z danego miasta bezpośrednia autostrada może prowadzić tylko w kierunku miasta leżącego w kolejnym (zgodnie z numeracją) województwie. Autostrady różnią się liczbą pasów. Kierowca po dojechaniu do miasta zawsze zjeżdża z autostrady i musi wjechać na nową autostradę, jeśli chce kontynuować podróż. Pomiędzy miastami kierowca musi jechać stale pasem, na który wjechał w ostatnim mieście.

Bajtockich kierowców interesuje liczba różnych tras prowadzących między wybranymi parami miast. Dwie trasy uważamy za identyczne tylko wtedy, gdy przechodzą przez dokładnie takie same miasta, a między miastami prowadzą po takich samych pasach. Z powodu ciągłych remontów i rozbudowy sieci, informacje o połączeniach trzeba często aktualizować.

Pomóż odpowiedzieć na serię pytań kierowców, uwzględniając przychodzące w międzyczasie aktualizacje informacji o autostradach. Wystarczy, że podasz resztę z dzielenia uzyskanej liczby przez ustaloną liczbę całkowitą d.

Napisz program, który:

  • wczyta dzielnik d, liczbę województw, liczbę miast w każdym województwie, opis początkowej sieci autostrad oraz serię pytań i aktualizacji,
  • dla każdego pytania obliczy liczbę tras, o których mowa w pytaniu, uwzględniając wcześniejsze aktualizacje,
  • wypisze reszty z dzielenia przez d uzyskanych liczb.

입력

Pierwszy wiersz zawiera dwie liczby całkowite dn (2 ≤ d ≤ 40000, 2 ≤ n ≤ 30000). Drugi wiersz zawiera ciąg m1m2,..., mn, w którym mk to liczba miast w k-tym województwie (1 ≤ mk ≤ 10). Dalej pojawiają się kolejno sekcje odpowiadające województwom o numerach 1, 2...n-1. Województwo o numerze k jest opisane w mk następnych wierszach. Wiersz o numerze i w danej sekcji opisuje autostrady wychodzące z i-tego miasta w województwie i zawiera liczby pk(i, 1), pk(i, 2), ..., pk(imk+1) (0 ≤ pk(ij) ≤ 109), gdzie pk(ij) oznacza liczbę pasów na autostradzie prowadzącej od i-tego miasta w k-tym województwie do j-tego miasta w następnym województwie (o numerze k + 1).

Kolejne wiersze wejścia zawierają pewną liczbę pytań i aktualizacji. Wiersz zaczynający się od znaku q, po którym następują cztery liczby całkowite kilj, oznacza pytanie o liczbę tras prowadzących od i-tego miasta w k-tym województwie, do j-tego miasta w l-tym województwie (1 ≤ k < ln, 1 ≤ imk, 1 ≤ jml). Wiersz zaczynający się od znaku u, po którym następują cztery liczby całkowite kijr, oznacza zmianę na r liczby dostępnych pasów między i-tym miastem k-tego województwa, a j-tym miastem następnego województwa (1 ≤ k < n, 1 ≤ imk, 1 ≤ jmk+1, 0 ≤ r ≤ 109). Wejście zakończone jest wierszem postaci e 0 0 0 0.

W sumie pytań i aktualizacji jest nie więcej niż 5000, nie licząc wiersza e 0 0 0 0.

출력

Twój program powinien wypisać serię wierszy zawierających po jednej liczbie całkowitej, stanowiących odpowiedzi na kolejne pytania. Liczba wierszy na wyjściu powinna być równa liczbie pytań. Każdy wiersz musi zawierać jedną liczbę całkowitą, równą reszcie z dzielenia przez d liczby tras między rozpatrywaną parą miast.

예제 입력 1

5 4
2 2 1 3
1 8
1 0
1
2
0 1 2
q 2 2 3 1
q 1 2 3 1
q 1 2 4 3
q 1 2 4 1
q 1 1 4 2
u 2 2 1 1
q 1 1 4 2
e 0 0 0 0

예제 출력 1

2
1
2
0
2
4