Informatică, întrebare adresată de bencheacatalin, 9 ani în urmă

VA ROG AJUTOR!

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

Acesta este codul meu:

#include
using namespace std;

ifstream fin("maxsim.in");
ofstream fout("maxsim.out");

int main()
{
int n, i, j, v[1000], a=0, b=0;

fin >> n;

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

for (i = 1, j=n; i <= n/2; i++, j--)
{
if (v[i] + v[j] > a+b)
{
a = v[i];
b = v[j];
}
}

fout << a+b << " " << a << " " << b;

return 0;
}

Răspunsuri la întrebare

Răspuns de NuPotSaStiuTot
0
daca pui si:
#include <iostream>
#include <fstream>
este perfect,

bencheacatalin: Nu stiu cum de am uitat sa le copiez (in codul original le am). Programul e functional, dar nu primesc 100 de puncte pe pbinfo.ro (primesc doar 20).
Dairrow: ai uitat cazul de n%2==1
Alte întrebări interesante