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

Cerința
Se dă un vector cu n elemente numere naturale. Determinați cea mai lungă secvență de elemente nule din vector. Dacă în vector există mai multe secvențe de elemente nule de lungime maximă se va determina cea mai din stânga.

Date de intrare
Programul citește de la tastatură numărul n, iar apoi n numere naturale, reprezentând elementele vectorului.

Date de ieșire
Programul va afișa pe ecran indicii st dr ai capetelor secvenței determinate, separați printr-un spațiu.

Restricții și precizări
1 ≤ n ≤ 1000
cele n numere citite vor fi mai mici decât 1000
indicii elementelor vectorului sunt cuprinși între 1 și n
vectorul va conține cel puțin un element nul

Exemplu
Intrare

10
0 1 0 0 0 5 0 0 0 2
Ieșire

3 5

Răspunsuri la întrebare

Răspuns de boiustef
4

#include <iostream>

using namespace std;

int main()

{

   int n, secmax=0, secv=0, i, num, st=0, dr=0;

   cin >> n;

   i=0;

   while (i<n)

   {

       ++i;

       cin >> num;

       if (num==0) ++secv;

       else

       {if (secv>secmax)

           { secmax=secv; dr=i-1; st=i-secv; }

          secv=0;

       }

   }

   if (secv>secmax) { secmax=secv; st=i+1-secv; dr=i; }

   cout << st << " " << dr;

   return 0;

}


boiustef: ind: 1 2 3 4 5 6 7 8 9 10
sir: 0 1 0 0 0 5 0 0 0 2
andreea21688: Multumesc
andreea21688: Asta am inteles
andreea21688: iar cu stanga?
boiustef: ind e indice, adică poziţia numărului în şir şi vezi a doua secvenţă de zerouri are st=3 şi dr=5
boiustef: ??? e greu?
andreea21688: Asta tot nu am inteles
andreea21688: nu e chiar asa de greu dar cu stanga tot nu am inteles
boiustef: succese!
andreea21688: Nu poti sa imi mai explici cu st?
Alte întrebări interesante