Informatică, întrebare adresată de pmarian98, 8 ani în urmă

#281 Maxim5

Cerinţa
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

Aici este si codul meu da decat 20%

#include
using namespace std;
ifstream f("maxim5.in");
ofstream g("maxim5.out");
int x, nr, Max, Max2, nr2 = 100000000;
int main()
{
while(f>>x) {
nr++;
if(!x) {
if(nr<=nr2) {
nr2=nr;
nr=0;
Max2=max(Max2,Max);
}
else
{
nr=0;
g< break;
}
}
else
if(nr<=nr2 && x>Max)
Max=x;
}
return 0;
}

Răspunsuri la întrebare

Răspuns de boiustef
4

#include <iostream>

#include <fstream>

using namespace std;

int main()

{

   ifstream f("maxim5.in");

   ofstream g("maxim5.out");

   int a, lungmin, leng, maxl, M;

    f >> a;

     maxl=a; leng=1;

     while (a!=0)

     {

         f >> a;

         if (a!=0) {  ++ leng; if (a>maxl) maxl=a; }

     }

     lungmin=leng; M=maxl;

     while (!f.eof())

     {

         f >> a;

         if (a) {

         maxl=a; leng=1;

         while (a!=0)

         {

            f >> a;

            if (a!=0) {  ++ leng; if (a>maxl) maxl=a; }

         }

         if (leng<lungmin) { lungmin=leng; M=maxl; }

         else if (leng==lungmin && maxl>M)  M=maxl;

         }

     }

       g << M << "\n";

   return 0;

}



pmarian98: nu in totalitate
pmarian98: solutia ta e mai usoara decat cea a lor
pmarian98: mersi!
boiustef: cred, faci bn ca compari cu solutia oficiala... eu aproape nicicand nu fac asta... ma multumesc cu faptul ca am luat rezultat pozitiv
pmarian98: LA MULTI ANI PT MAINE
pmarian98: Maine nu mai intru pe site
boiustef: ok, pauza, multi ani cu sanatate, succese !
pmarian98: la fel
Lorraine: cum este solutia oficiala? mie asta imi da 0p
Lorraine: Nu mai conteaza....am scris eu ceva gresit
Alte întrebări interesante