Î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 , ale cărei elemente codifică zone pătratice, cu latura de 1 metru. Acestea pot fi:
- zonă care conține apă, marcată cu ;
- zonă care conține doar pământ, marcată cu ; 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:
- Câte comori se găsesc pe insula pe care se află căpitanul Poseidon?
- 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 .
Date de intrare
Fișierul de intrare poseidon.in
conține pe prima linie numărul natural , reprezentând cerința care trebuie rezolvată ( sau ).
Pe a doua linie, se află două numere naturale și 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 linii se află câte numere întregi, reprezentând codificarea zonelor matricei.
Pentru cazul în care , pe ultima linie a fișierului se mai află două numere naturale si , 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ă , numărul total de comori precizat la cerința 1, iar dacă , numărul de soluții de plasare precizate la cerința 2, în forma indicată.
Restricții și precizări
- ;
- ;
- Elementele matricei au valori întregi din intervalul []. Matricea este indexată începând cu .
- 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.
- , , zona dată de și conține pământ.
- Notăm cu numarul maxim de comori de pe o singură insulă.
# | Punctaj | Restricții |
---|---|---|
1 | 5 | și există o singură insulă |
2 | 10 | și |
3 | 26 | , fără alte restricții |
4 | 13 | și |
5 | 17 | și |
6 | 29 | , 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 și cea care conține comorile . Poseidon se află pe insula care conține comorile .
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 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