Poseidon

Time limit: 0.5s Memory limit: 128MB Input: poseidon.in Output: poseidon.out

În Tărâmul Magic al Insulelor, se desfășoară o vânătoare anuală de comori, unde echipele explorează insule fermecate, delimitate de apa ce le înconjoară. La ordinul regelui A., sunt ascunse comori pe fiecare insulă. Harta tărâmului este reprezentată sub forma unei matrice de dimensiune n×mn \times m, ale cărei elemente codifică zone pătratice, cu latura de 1 metru. Acestea pot fi:

  • zonă care conține apă, marcată cu 1-1;
  • zonă care conține doar pământ, marcată cu 00; sau
  • zonă care conține pământ și o singură comoară, marcată cu un număr natural nenul.

Două zone se consideră vecine dacă au o latură comună. Două zone aparţin aceleiaşi insule dacă ele sunt vecine sau dacă se poate ajunge de la o zonă la cealaltă pe un drum care parcurge o succesiune de zone, oricare două zone parcurse consecutiv fiind vecine. În acest an, căpitanul Poseidon dorește să facă o farsă regelui A., permutând comorile, astfel încât fiecare comoară să fie mutată într-o zona în care inițial a fost o altă comoară. Totuși, pentru a nu atrage atenția prea mult, comorile vor rămâne în cadrul insulei pe care se aflau inițial.

Cerință

Pentru început, căpitanul Poseidon își propune să rezolve următoarele cerințe:

  1. Câte comori se găsesc pe insula pe care se află căpitanul Poseidon?
  2. Câte soluții există pentru plasarea tuturor comorilor, astfel încât fiecare comoară să fie mutată în cadrul aceleiași insule, într-o zonă în care inițial a fost o altă comoară? Pentru că numărul de soluții poate fi foarte mare, răspunsul va fi afișat modulo 1 000 000 0071 \ 000 \ 000 \ 007.

Date de intrare

Fișierul de intrare poseidon.in conține pe prima linie numărul natural cc, reprezentând cerința care trebuie rezolvată (11 sau 22).

Pe a doua linie, se află două numere naturale nn și mm reprezentând, în această ordine, numărul de linii, respectiv numărul de coloane ale hărții Tărâmului Magic al Insulelor. Pe fiecare din următoarele nn linii se află câte mm numere întregi, reprezentând codificarea zonelor matricei.
Pentru cazul în care c=1c=1, pe ultima linie a fișierului se mai află două numere naturale xPx_P si yPy_P, reprezentând linia și coloana zonei în care se află Poseidon.

Date de ieșire

Fișierul de ieșire poseidon.out va conține pe prima linie un număr natural: dacă c=1c=1, numărul total de comori precizat la cerința 1, iar dacă c=2c=2, numărul de soluții de plasare precizate la cerința 2, în forma indicată.

Restricții și precizări

  • 1c21 \le c \leq 2;
  • 1n,m1 0001 \le n, m \leq 1 \ 000;
  • Elementele matricei au valori întregi din intervalul [1,nm-1, n \cdot m]. Matricea este indexată începând cu 11.
  • Oricare două zone distincte care conțin câte o comoară vor fi descrise prin numere distincte.
  • Insulele sunt formate din zone compacte de pământ. Se garantează că nu conțin apă în interior.
  • 1xPn1 \le x_P \le n, 1yPm1 \le y_P \le m, zona dată de xPx_P și yPy_P conține pământ.
  • Notăm cu ncn_c numarul maxim de comori de pe o singură insulă.
# Punctaj Restricții
1 5 c=1c=1 și există o singură insulă
2 10 c=1c=1 și n=1n = 1
3 26 c=1c=1, fără alte restricții
4 13 c=2c=2 și nc4n_c \leq 4
5 17 c=2c=2 și nc8n_c \leq 8
6 29 c=2c=2, fără alte restricții

Exemplul 1

poseidon.in

1
8 6
-1 -1 -1 -1 -1 -1
-1 0 0 -1 -1 -1
-1 9 1 0 -1 -1
-1 3 4 0 -1 -1
-1 0 0 -1 0 -1
-1 -1 -1 5 10 -1
-1 -1 0 6 7 -1
-1 -1 -1 -1 -1 -1
2 2

poseidon.out

4

Explicație

Există două insule, cea care conține comorile 1,3,4,91,3,4,9 și cea care conține comorile 5,6,7,105,6,7,10. Poseidon se află pe insula care conține comorile 1,3,4,91,3,4,9.

Exemplul 2

poseidon.in

2
8 6
-1 -1 -1 -1 -1 -1
-1 0 0 -1 -1 -1
-1 9 1 0 -1 -1
-1 3 4 0 -1 -1
-1 0 0 -1 0 -1
-1 -1 -1 5 0 -1
-1 -1 0 6 8 -1
-1 -1 -1 -1 -1 -1

poseidon.out

18

Explicație

Sunt 1818 moduri de a rearanja comorile. Unul dintre acestea este:

-1 -1 -1 -1 -1 -1
-1  0  0 -1 -1 -1
-1  3  9  0 -1 -1
-1  4  1  0 -1 -1
-1  0  0 -1  0 -1
-1 -1 -1  6  0 -1
-1 -1  0  8  5 -1
-1 -1 -1 -1 -1 -1

Log in or sign up to be able to send submissions!