Pagini recente » Cod sursa (job #2873827) | Cod sursa (job #1909870) | Clasamentul arhivei Infoarena Monthly | Cod sursa (job #2850266) | Cod sursa (job #2643086)
#include <iostream>
#include <fstream>
#include <vector>
#include <algorithm>
#include <limits.h>
using namespace std;
int n, k, nr, v[50005];
int main(){
//ifstream fin("date.in");
ifstream fin("secv2.in");
ofstream fout("secv2.out");
fin >> n >> k;
for(int i = 1; i <= n; ++i){
fin >> nr;
v[i] += v[i-1] + nr;
//cout << v[i] << " ";
}
// cout << '\n';
int maxim = INT_MIN;
int minim = 0, posMinim = 0;
pair<int,int> posMaxim;
for(int i = 1; i <= n - k + 1; ++i){
//cout << i << " " << i + k - 1<< "\n";
if(minim > v[i-1]){
minim = v[i-1];
posMinim = i-1;
}
if(maxim < v[i + k - 1] - v[posMinim]){
maxim = v[i + k - 1] - v[posMinim];
posMaxim.first = i + k - 1;
posMaxim.second = posMinim + 1;
}
}
fout <<posMaxim.second << " " << posMaxim.first << " " << maxim ;
return 0;
}