Detalii evaluare #53942803

Rezumat problemă

#3277 Lee

Se consideră o matrice cu N linii și N coloane, numerotate de la 1 la N, care memorează doar valori 0 și 1. Se dau de asemenea coordonatele a trei componente din această matrice. Să se determine lungimea minimă a unui drum care pleacă din poziția (1,1), trece obligatoriu prin cele trei componente date (nu contează în ce ordine) și apoi ajunge în poziția (N, N), drum care trece doar prin componente marcate cu 0 și învecinate pe linii și coloane.

Detalii

Problema Lee Operații I/O tastatură/ecran
Limita timp 0.1 secunde Limita memorie Total: 64 MB / Stivă 8 MB
Id soluție #53942803 Utilizator Selagea Romina (MadalinaSelagea)
Fișier lee.cpp Dimensiune 1.85 KB
Data încărcării 15 Noiembrie 2024, 12:32 Scor / rezultat Eroare de compilare

Evaluare


Mesaj compilare

lee.cpp:11:11: error: 'int j1' redeclared as different kind of symbol
 int x1,x2,j1,j2,prim,ultim,n,i,k,j,m,s=0,j3,x3,aux,nr1,nr2,nr3,v[4],b[1001][1001];

           ^
In file included from /usr/include/features.h:374:0,
                 from /usr/include/i386-linux-gnu/c++/4.8/bits/os_defines.h:39,
                 from /usr/include/i386-linux-gnu/c++/4.8/bits/c++config.h:426,
                 from /usr/include/c++/4.8/iostream:38,
                 from lee.cpp:1:
/usr/include/i386-linux-gnu/bits/mathcalls.h:238:1: error: previous declaration of 'double j1(double)'
 __MATHCALL (j1,, (_Mdouble_));
 ^
lee.cpp: In function 'int main()':
lee.cpp:62:6: error: cannot bind 'std::basic_istream<char>::__istream_type {aka std::basic_istream<char>}' lvalue to 'std::basic_istream<char>&&'
     f>>x1>>j1>>x2>>j2>>x3>>j3;

      ^
In file included from /usr/include/c++/4.8/iostream:40:0,
                 from lee.cpp:1:
/usr/include/c++/4.8/istream:872:5: error:   initializing argument 1 of 'std::basic_istream<_CharT, _Traits>& std::operator>>(std::basic_istream<_CharT, _Traits>&&, _Tp&) [with _CharT = char; _Traits = std::char_traits<char>; _Tp = double(double)throw ()]'
     operator>>(basic_istream<_CharT, _Traits>&& __is, _Tp& __x)
     ^
lee.cpp:63:15: warning: pointer to a function used in arithmetic [-Wpointer-arith]
     nr1=x1*10+j1;

               ^
lee.cpp:63:14: error: invalid conversion from 'double (*)(double)throw ()' to 'int' [-fpermissive]
     nr1=x1*10+j1;

              ^
lee.cpp:73:11: error: assignment of function 'double j1(double)'
         j1=v[1]%10;

           ^
lee.cpp:73:11: error: cannot convert 'int' to 'double(double)throw ()' in assignment
lee.cpp:76:24: error: invalid conversion from 'double (*)(double)throw ()' to 'int' [-fpermissive]
         lee(1,1,x1,j1,s);

                        ^
lee.cpp:12:8: error:   initializing argument 4 of 'void lee(int, int, int, int, int&)' [-fpermissive]
   void lee(int x1,int j1,int x2, int j2,int &s)

        ^
lee.cpp:85:26: error: invalid conversion from 'double (*)(double)throw ()' to 'int' [-fpermissive]
         lee(x1,j1,x2,j2,s);

                          ^
lee.cpp:12:8: error:   initializing argument 2 of 'void lee(int, int, int, int, int&)' [-fpermissive]
   void lee(int x1,int j1,int x2, int j2,int &s)

        ^

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 Lee 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ă.