189192025-11-12 17:17:46KristófMaximális szorzat (50 pont)cpp17Runtime error 43/5082ms1040 KiB
#include <iostream>
#include <vector>
#include <queue>
using namespace std;

long long mod=1000000007;


int main()
{
    int n,k,b;
    cin>>n>>k>>b;
    priority_queue<int> negativ,poz;
    int x;
    for(int i=0;i<n;i++)
        {
        cin>>x;
        if(x>-1)
            {
            poz.push(x*-1);
            }
        else
            {
            negativ.push(x);
            }
        }
    if(negativ.size()<b)
        {
        cout<<-1;
        return 0;
        }
    if(negativ.size() == b)
        {
        while(k--)
            {
            x=poz.top()*-1;poz.pop();
            poz.push((x+1)*-1);
            }
        }
    else
        {
        while(negativ.size()!=b)
            {
            k+=negativ.top();
            if(k<0)
                {
                cout<<-1;
                return 0;
                }
            poz.push(0);
            negativ.pop();
            }

        while(k--)
            {
            x=poz.top()*-1;poz.pop();
            poz.push((x+1)*-1);
            }
        }


    long long ans=1;
    while(!poz.empty())
        {

        ans*=(poz.top()*-1)% mod;poz.pop();
        ans = ans % mod;
        }
    while(!negativ.empty())
        {
        ans*=abs(negativ.top()) % mod;negativ.pop();
        ans = ans % mod;
        }
    cout<<ans;
    return 0;
}
SubtaskSumTestVerdictTimeMemory
base43/50
1Accepted0/01ms316 KiB
2Accepted0/01ms316 KiB
3Accepted0/01ms316 KiB
4Accepted0/01ms508 KiB
5Accepted0/04ms316 KiB
6Accepted2/21ms316 KiB
7Accepted2/21ms316 KiB
8Accepted2/21ms316 KiB
9Accepted2/21ms316 KiB
10Accepted2/27ms316 KiB
11Accepted2/271ms944 KiB
12Accepted1/179ms1040 KiB
13Accepted1/12ms316 KiB
14Accepted1/18ms456 KiB
15Accepted1/118ms488 KiB
16Accepted1/143ms796 KiB
17Accepted1/118ms676 KiB
18Accepted1/112ms708 KiB
19Runtime error0/137ms944 KiB
20Runtime error0/128ms888 KiB
21Runtime error0/154ms808 KiB
22Runtime error0/124ms944 KiB
23Accepted1/182ms888 KiB
24Accepted1/179ms904 KiB
25Accepted2/22ms316 KiB
26Accepted2/27ms316 KiB
27Runtime error0/228ms768 KiB
28Runtime error0/128ms768 KiB
29Accepted2/220ms620 KiB
30Accepted1/172ms936 KiB
31Accepted1/135ms924 KiB
32Accepted2/22ms316 KiB
33Accepted2/274ms844 KiB
34Accepted1/175ms940 KiB
35Accepted2/275ms844 KiB
36Accepted2/271ms816 KiB
37Accepted2/275ms944 KiB
38Accepted2/272ms1020 KiB
39Accepted1/12ms316 KiB