fbpx

Problema #165 – maxsim – Rezolvari PBInfo

de Mihai-Alexandru

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
#include <bits/stdc++.h>
using namespace std ;
ifstream fin("maxsim.in");
ofstream fout("maxsim.out");
int main()
{
    int n , a[1001] , i1 = 0 , i2 = 0 , maxi = -1 ;
    fin >> n;
    for(int i = 1 ; i <= n ; ++i)fin >> a[i];
    for(int i = 1 ; i <= n / 2; ++i)
    {
        if(a[i] + a[n - i + 1] > maxi)
        {
            maxi = a[i] + a[n - i + 1];
            i1 = i;
            i2 = n - i + 1;
        }
    }
    fout << maxi << " " << i1 << " " << i2;
    return 0;
}
Comentarii

S-ar putea sa iti placa