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; }