#1332
TraseuCal
Se dă o tablă de șah formată din n
linii și m
coloane, definind n*m
zone, unele dintre ele fiind libere, altele conținând obstacole. În zona de coordonate 1 1
se află un cal care se poate deplasa pe tablă în L
, ca la șah, fără a părăsi tabla, fără a trece prin zone care conțin obstacole și fără a trece de două ori prin aceeași zonă.
Determinați o modalitate prin care calul poate ajunge în zona de coordonate n m
– unde se află o căpiță de fân.
Problema | TraseuCal | Operații I/O |
traseucal.in /traseucal.out
|
---|---|---|---|
Limita timp | 1 secunde | Limita memorie |
Total: 64 MB
/
Stivă 8 MB
|
Id soluție | #21459325 | Utilizator | |
Fișier | traseucal.cpp | Dimensiune | 752 B |
Data încărcării | 02 Martie 2020, 11:48 | Scor / rezultat | Eroare de compilare |
traseucal.cpp: In function 'void afis()': traseucal.cpp:5:166: error: expected '}' at end of input ifstream fin("soarece.in"); ofstream fout("soarece.out"); int n,m,is,js,ib,jb,a[11][11], nrsol = 0; const int di[]={0,0,1,-1}, dj[]={1,-1,0,0}; void afis(){ nrsol++;; //for(int i=1;i<=n;++i){ // for(int j=1;j<=m;++j) // cout << setw(3) << a[i][j]; // cout << endl; //} //cout << endl; } void back(int i,int j, int pas) { if(i>0 && i<=n && j>0 && j<=m && a[i][j]==0) { a[i][j] = pas; if(i==ib && j==jb) afis(); else for(int k=0;k<4;++k) back(i+di[k], j+dj[k], pas+1); a[i][j] = 0; } } int main() { fin >> n >> m; for(int i=1;i<=n;++i) for(int j=1;j<=m;++j) fin >> a[i][j], a[i][j] = -a[i][j]; fin >> is >> js >> ib >> jb; back(is, js, 1); fout << nrsol; return 0; } ^
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema TraseuCal face parte din prima categorie. Soluția propusă de tine va fi evaluată astfel:
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ă.