Fişierul intrare/ieşire:map.in, map.outSursăPACO 2006
AutorSorin Stancu-MaraAdăugată de
Timp execuţie pe test0.1 secLimită de memorie65536 kbytes
Scorul tăuN/ADificultatenormalnormalnormalnormalnormal

Vezi solutiile trimise | Statistici

Map

Max Damage, pentru a nu se pierde in calatoriile sale doreste sa isi faca o harta. Pentru a nu fi citita de oricine, el o codifica sub forma unei matrice cu N linii si M coloane. Pentru ca scrie urat, se duce la un prieten care are un tipar si il roaga sa ii tipareasca harta. Tiparul, fiind mai vechi, este stricat si tipareste harta de doua ori pe aceeasi foaie, dar cu o deplasare (spre dreapta).
Apare politia si Max fuge cu foaia prost tiparita. Ajuns la ascunzatoare el vede catastrofa: portiunea unde cele doua imprimari s-au suprapus se intampla sa coincida, astfel ca nu isi poate da seama unde se termina una si unde incepe cealalta. El vrea acum un program care, primind o astfel de matrice, sa returneze cea mai mica dimensiune a matricei originale astfel incat, suprapusa de doua ori cu o deplasare corecta spre dreapta, sa se obtina cea finala

Ajutati-l pe Max sa rezolve si aceasta problema zdrobitoare.

Date de Intrare

Prima linie din fisierul map.in va contine numerele M si N, reprezetand dimensiunea matricei. Urmatoarele M linii vor contine cate N litere mici ale alfabetului englez (matricea prost tiparita).

Date de Iesire

Fiserul map.out va contine pe prima linie o singura valoare, reprezentand dimensiunea orizontala minima a matricei originale.

Restrictii si observatii

  • 1 ≤ N, M ≤ 2000

Example

map.inmap.out
3 5
anana
arara
mamam
3

Explicatie

Pornind de la matricea de lungime 3
ana
ara
mam
suprapusa de doua ori se obtine:
anana
arara
mamam

map.inmap.out
1 4
abcd
4

Explicatie

Singura solutie este ca a doua imprimare sa fie perfect suprapusa peste prima.

map.inmap.out
1 4
aaaa
3

Explicatie

Daca lungimea ar fi fost mai mica, nu se suprapunea.

Trebuie sa te autentifici pentru a trimite solutii. Click aici

Cum se trimit solutii?

remote content