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

Se dau n numere naturale reprezentând elementele unui vector.

Cerinţa
Să se determine perechea de elemente egal depărtate de centru pentru care suma valorilor este maximă. Dacă sunt mai multe perechi cu suma maximă se va determina perechea cea mai apropiată de capete.

Date de intrare
Fişierul de intrare maxsim.in conţine pe prima linie numărul n, iar pe a doua linie n numere naturale separate prin spaţii, reprezentând elementele vectorului.

Date de ieşire
Fişierul de ieşire maxsim.out va conţine pe prima linie trei numere S, i, j, separate prin exact un spațiu, reprezentând suma maximă obținuta și pozițiile elementelor din pereche.

Restricţii şi precizări
0 < n ≤ 1000
numerele de pe a doua linie a fişierului de intrare vor fi mai mici decât 1.000.000.000
elementele vectorului se consideră numerotate de la 1
1 ≤ i < j ≤ n

Exemplu
maxsim.in

7
6 2 5 4 3 6 1
maxsim.out

8 2 6


ajutor..

Răspunsuri la întrebare

Răspuns de boiustef
4

Răspuns:

#include <iostream>

#include <fstream>

using namespace std;

ifstream f("maxsim.in");

ofstream g("maxsim.out");

int n, i, v[1001], summax, poz, s;

int main()

{

   f >> n;

   for (i=1; i<=n; ++i) f >> v[i];

   for (i=1; i<=n/2; ++i)

   {

       s=v[i]+v[n+1-i];

       if (s>summax)

       {

           summax=s; poz=i;

       }

   }

   g << summax << " " << poz << " " << n+1-poz;

}

Explicație:

Alte întrebări interesante