fbpx

Problema #281 – Maxim5 – Rezolvari PBInfo

de Mihai-Alexandru

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
#include <bits/stdc++.h>
using namespace std;

ifstream cin("maxim5.in");
ofstream cout("maxim5.out");

int main()
{
    int n=0;
    int a[100000];
    a[0]=0;
    n=1;
    while(cin >> a[n])
        n++;
    int l = 0 , lmax = 100000 , st , dr;
    for(int i = 1 ; i < n ; ++i)
    {
        if(a[i]==0)
        {
            if(l<lmax && l>0)
            lmax=l , st=i-l , dr=i;
            l=0;
        }
        else
        l++;
    }
    int max=0;
    for(int i = 1 ; i < n ; ++i)
    {
        if(a[i]==0)
        {
            if(l==lmax)
            {
                for(int j = i - lmax ; j <= i ; ++j)
                    if(a[j]>max)
                        max=a[j];
            }
            l=0;
        }
        else
        l++;
    }
    cout << max;
}
Comentarii

S-ar putea sa iti placa