Se dă un fişier text care conţine mai multe linii, pe fiecare linie existând câte un şir de numere naturale nenule, despărţite prin câte un spaţiu; fiecare linie se termină cu numarul 0 (care se consideră că nu face parte din şirul aflat pe linia respectivă) şi conţine cel puţin două valori.
Se cere să se afişeze valoarea maximă din şirul care conţine cele mai puţine numere. În cazul în care există mai multe şiruri cu acelaşi număr minim de numere, se va afişa cea mai mare valoare care apare în unul dintre aceste şiruri.
Date de intrare
Fişierul de intrare maxim5.in conţine şirurile de numere, aşa cu a fost descris mai sus.
Date de ieşire
Fişierul de ieşire maxim5.out va conţine pe prima linie numărul M, reprezentând valoarea maximă din şirul care conţine cele mai puţine numere.
Restricţii şi precizări
numerele din şirurile date au cel mult 9 cifre
Exemplu:
maxim5.in
2 253 34 3 0
6 88 9 3 0
4 54 88 12345 98 234 546 0
maxim5.out
253
Frost:
E din 2008/2009?
Răspunsuri la întrebare
Răspuns de
9
#include <fstream>
using namespace std;
ofstream fout("maxim5.out");
ifstream fin("maxim5.in");
int x, nr, Max, Max2, nr2 = 100000000;
int main()
{
while(fin >> x) {
nr++;
if(!x) {
if(nr <= nr2) {
nr2 = nr; nr = 0;
Max2 = max(Max2, Max); Max = 0;
}
else { nr = 0; Max = 0; }
}
else if(nr <= nr2 && x > Max) Max = x;
}
fout << Max2;
return 0;
}
using namespace std;
ofstream fout("maxim5.out");
ifstream fin("maxim5.in");
int x, nr, Max, Max2, nr2 = 100000000;
int main()
{
while(fin >> x) {
nr++;
if(!x) {
if(nr <= nr2) {
nr2 = nr; nr = 0;
Max2 = max(Max2, Max); Max = 0;
}
else { nr = 0; Max = 0; }
}
else if(nr <= nr2 && x > Max) Max = x;
}
fout << Max2;
return 0;
}
Alte întrebări interesante
Matematică,
8 ani în urmă
Biologie,
8 ani în urmă
Engleza,
8 ani în urmă
Limba română,
9 ani în urmă
Limba română,
9 ani în urmă
Matematică,
9 ani în urmă
Limba română,
9 ani în urmă
Biologie,
9 ani în urmă