Detalii evaluare #49963619

Rezumat problemă

#1785 MZ

Fericit că s-a calificat la ONI, XORin vrea să sărbătorească făcând cât mai mult zgomot. Deoarece e programator, acesta s-a gândit să automatizeze felul în care face zgomot.

Pentru a face zgomot el folosește o placă cu circuite de diverse intensități. Placa poate fi reprezentată sub forma unei matrice cu N linii și M coloane. Fiecare celulă din matrice are o intensitate între 0 și 9 (o celulă cu intensitatea 0 corespunde unei zone goale, fără nici un circuit).

Un circuit începe într-o celulă a matricei și se termină în altă celulă, fiind o succesiune de celule adiacente de aceeași intensitate de la un capăt la celălalt al circuitului, asemenea unui drum pe matrice între cele două celule. Două celule se consideră adiacente dacă au o latură comună, deci o celulă e adiacentă cu maxim patru alte celule.

Placa a fost concepută în așa fel încât să nu apară scurtcircuite, așadar curentul dintr-un circuit poate merge numai într-o singură direcție (cu alte cuvinte, fiecare celulă dintr-un circuit se învecinează cu maxim alte două celule din același circuit). Nu există circuite de aceeași intensitate care să se învecineze.

Zgomotul produs de un circuit este egal cu lungimea lui, adică cu numărul de celule din matrice corespunzătoare circuitului.

Cerințe:

1) Să se afle numărul de circuite.
2) Să se afle valoarea zgomotului maxim care poate fi obținut unind două circuite. Două circuite pot fi unite dacă se poate trage o legătură de la un capăt al unui circuit până la un capăt al celuilalt circuit, numai prin celulele libere ale matricei (de intensitate 0). Legătura trebuie să aibă forma unui circuit. Lungimea circuitului nou creat nu se adaugă la zgomotul produs de cele doua circuite.
3) Să se afișeze placa ce conține legătura care unește două circuite din care se obține zgomotul maxim de la cerința 2. Dacă există mai multe variante, se poate afișa orice placă care conține legătura validă.

Concursul Interjudeţean de Matematică şi Informatică Grigore Moisil, 2016

Detalii

Problema MZ Operații I/O mz.in/mz.out
Limita timp 2.5 secunde Limita memorie Total: 64 MB / Stivă 32 MB
Id soluție #49963619 Utilizator Morariu Tudor (rake2008)
Fișier mz.cpp Dimensiune 5.98 KB
Data încărcării 21 Martie 2024, 12:20 Scor / rezultat 19 puncte

Evaluare


Mesaj compilare

mz.cpp: In function 'void debug(std::vector<int>)':
mz.cpp:22:30: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
     for(int i = 0;i < v.size();i++) cout << v[i] << " ";

                              ^
mz.cpp: In function 'int main()':
mz.cpp:219:43: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
         for(int i = 0;i < it->second.size();i++)

                                           ^
mz.cpp:221:51: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
             for(int j = i + 1;j < it->second.size();j++)

                                                   ^

Rezultat evaluare

Test Timp Mesaj evaluare Scor posibil Scor obținut
0 0 secunde Incomplet! 10 5
1 0 secunde Incomplet! 10 2
2 0 secunde Incomplet! 10 2
3 0 secunde Incomplet! 10 5
4 0.312 secunde Incomplet! 10 5
5 Depășit Limita de timp depășită 10 0
6 Depășit Limita de timp depășită 10 0
7 Depășit Limita de timp depășită 10 0
8 Depășit Limita de timp depășită 10 0
9 Depășit Limita de timp depășită 10 0
Punctaj total 19

Cum funcționează evaluarea?

www.pbinfo.ro permite evaluarea a două tipuri de probleme:

  • probleme la care rezolvarea presupune scrierea unui program complet
  • probleme la care rezolvarea presupune scrierea unei secvențe de program - câteva instrucțiuni, o listă de declarații, una sau mai multe funcții, etc.

Problema MZ face parte din prima categorie. Soluția propusă de tine va fi evaluată astfel:

  • Programul sursă este compilat folosind compilatorul corespunzător. Dacă în urma compilării se obțin erori sau avertismente, acestea sunt afișate în această pagină.
  • Dacă programul a fost compilat, executabilul obținut va fi rulat, furnizându-i-se unul sau mai multe seturi de date de intrare, în concordanță cu restricțiile specifice problemei. Pentru fiecare set de date se obține un anumit punctaj, în raport cu corectitudinea soluției tale.

Suma punctajelor acordate pe testele utilizate pentru verificare este 100. Astfel, soluția ta poate obține cel mult 100 de puncte, caz în care se poate considera corectă.