219572026-01-14 11:13:56bombinigusiniSípálya (55 pont)cpp17Hibás válasz 52/5581ms1252 KiB
#include <iostream>
#include <vector>
using namespace std;
int main()
{
    int n, k;
    cin>>n>>k;
    vector<int> v(n);
    for(int i=0; i<n; i++) cin>>v[i];
    long long osszeg=0, minpetak=k*k+1/2+1, maxszam=v[0]-k, p;
    for(int i=0; i<k; i++)
    {
        osszeg+=v[i]+i-k;
        if(v[i]+i-k>maxszam)
        {
            p=i;
            maxszam=v[i]+i-k;
        };
    }
    minpetak=maxszam*k-osszeg;
    for(int i=1; i<n-k; i++)
    {
        maxszam--;
        if(i==p+1)
        {
            maxszam=v[i]-k;
            for(int j=0; j<k; j++)
            {
                if(v[i+j]-k+j>=maxszam)
                {
                    p=i+j;
                    maxszam=v[i+j]+j-k;
                }
            }
        }
        else if(v[i+k-1]-1>=maxszam)
        {
            maxszam=v[i+k-1]-1;
            p=i+k-1;
        }
        osszeg=osszeg-v[i-1]+v[i+k-1];
        if(k*maxszam-osszeg<minpetak)minpetak=k*maxszam-osszeg;
    }
cout<<minpetak;
return 0;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base52/55
1Elfogadva0/01ms336 KiB
2Elfogadva0/01ms316 KiB
3Elfogadva2/21ms316 KiB
4Elfogadva2/22ms316 KiB
5Elfogadva2/22ms404 KiB
6Elfogadva2/22ms364 KiB
7Elfogadva3/31ms404 KiB
8Elfogadva1/14ms444 KiB
9Elfogadva1/14ms432 KiB
10Elfogadva1/14ms432 KiB
11Elfogadva1/14ms432 KiB
12Hibás válasz0/14ms356 KiB
13Elfogadva1/14ms436 KiB
14Elfogadva2/24ms512 KiB
15Elfogadva2/24ms316 KiB
16Elfogadva2/275ms1192 KiB
17Hibás válasz0/274ms1196 KiB
18Elfogadva2/272ms1076 KiB
19Elfogadva3/374ms1200 KiB
20Elfogadva2/275ms1076 KiB
21Elfogadva2/274ms1192 KiB
22Elfogadva2/275ms1192 KiB
23Elfogadva2/275ms1188 KiB
24Elfogadva2/281ms1192 KiB
25Elfogadva2/275ms1192 KiB
26Elfogadva2/275ms1196 KiB
27Elfogadva2/274ms1252 KiB
28Elfogadva3/375ms1196 KiB
29Elfogadva3/374ms1076 KiB
30Elfogadva3/375ms1076 KiB