#4261
Folosind metoda Divide et Impera, scrieți funcția recursivă cu antetul
int AlternDivImp(int a[], int st, int dr)
care primind ca parametri un vector a de numere naturale și două numere întregi st și dr, returnează 1 dacă în secvența a[st], a[st+1], ..., a[dr] numerele impare alternează cu cele pare, sau returnează 0 dacă există cel puțin două numere alăturate de aceeași paritate.
| Problema | AlternDivImp | Operații I/O |
alterndivimp.in/alterndivimp.out
|
|---|---|---|---|
| Limita timp | 0.1 secunde | Limita memorie |
Total: 64 MB
/
Stivă 8 MB
|
| Id soluție | #61412877 | Utilizator | |
| Fișier | alterndivimp.cpp | Dimensiune | 310 B |
| Data încărcării | 27 Noiembrie 2025, 07:35 | Scor/rezultat | Eroare de compilare |
alterndivimp.cpp: In function 'int AlternDivImp(int*, int, int)': alterndivimp.cpp:7:15: warning: suggest parentheses around assignment used as truth value [-Wparentheses] if(st=dr-1){ ^ alterndivimp.cpp:8:29: error: return-statement with no value, in function returning 'int' [-fpermissive] if(a[st]+a[dr]%2==1)return; ^ alterndivimp.cpp:12:5: error: expected ';' before 'else' else return AlternDivImp(a,st,kozep-1)*AlternDivImp(a,kozep,dr-1)} ^ alterndivimp.cpp:12:70: error: expected ';' before '}' token else return AlternDivImp(a,st,kozep-1)*AlternDivImp(a,kozep,dr-1)} ^
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema AlternDivImp face parte din a doua categorie. Pentru aceste probleme se folosește un program suport, furnizat de propunătorul problemei. 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ă.