142762025-01-10 11:28:38TundeMaximális szorzat (50 pont)cpp17Időlimit túllépés 6/50600ms784 KiB
#include <iostream>
#include <algorithm>

using namespace std;

int main()
{
    long long n, k, b, db=0;
    long long szor=1;
    cin >> n >> k >> b;
    int t[n];
    for(int i=0; i<n; i++)
    {
        cin >> t[i];
        if(t[i]<0)
            ++db;
    }
    if(db<b)
        cout << -1;
    else
    {
        sort(t, t+n);
        long long i=0;
        while(db>b && i<k)
        {
            if(db%2==0)
            {
                if((t[db-1]+t[db-2])+(k-i)>=0)
                {
                    t[db-2]=0;
                    t[db-1]=0;
                    i-=t[db-2];
                    i-=t[db-1];
                    db=db-2;
                }
                else
                    i=k+1;
            }
            else
            {
                if(t[db-1]+k>=0)
                {
                    i-=t[db-1];
                    t[db-1]=0;
                    db--;
                }
                else
                {
                    i=k+1;
                }
            }
        }
        if(db!=b)
            cout << -1;
        else
        {
            while(i<k)
            {
                t[b]++;
                sort(t+b, t+n);
                i++;
            }
            for(int i=0; i<n; i++)
            {
                szor*=t[i];
                if(szor==0)
                    break;
            }
            cout << szor%(1000000000+7);
        }
    }
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base6/50
1Elfogadva0/01ms316 KiB
2Elfogadva0/01ms316 KiB
3Elfogadva0/01ms316 KiB
4Elfogadva0/01ms508 KiB
5Időlimit túllépés0/0598ms428 KiB
6Elfogadva2/21ms376 KiB
7Hibás válasz0/21ms316 KiB
8Hibás válasz0/21ms400 KiB
9Hibás válasz0/220ms396 KiB
10Időlimit túllépés0/2600ms316 KiB
11Időlimit túllépés0/2589ms568 KiB
12Időlimit túllépés0/1600ms756 KiB
13Hibás válasz0/168ms508 KiB
14Időlimit túllépés0/1600ms316 KiB
15Időlimit túllépés0/1600ms564 KiB
16Időlimit túllépés0/1600ms460 KiB
17Időlimit túllépés0/1582ms564 KiB
18Elfogadva1/19ms624 KiB
19Hibás válasz0/141ms720 KiB
20Hibás válasz0/130ms564 KiB
21Hibás válasz0/159ms532 KiB
22Hibás válasz0/125ms676 KiB
23Időlimit túllépés0/1598ms564 KiB
24Időlimit túllépés0/1600ms528 KiB
25Hibás válasz0/27ms508 KiB
26Hibás válasz0/210ms316 KiB
27Hibás válasz0/228ms544 KiB
28Hibás válasz0/128ms432 KiB
29Elfogadva2/217ms508 KiB
30Hibás válasz0/159ms784 KiB
31Elfogadva1/141ms544 KiB
32Hibás válasz0/23ms316 KiB
33Hibás válasz0/261ms784 KiB
34Hibás válasz0/163ms748 KiB
35Hibás válasz0/2158ms752 KiB
36Hibás válasz0/259ms756 KiB
37Hibás válasz0/259ms656 KiB
38Hibás válasz0/259ms748 KiB
39Hibás válasz0/13ms316 KiB