189252025-11-12 17:33:15KristófMaximális szorzat (50 pont)cpp17Hibás válasz 44/5085ms1048 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 && n!=b)
        {
        while(k--)
            {
            x=poz.top()*-1;poz.pop();
            poz.push((x+1)*-1);
            }
        }
    else if(negativ.size() > b)
        {
        while(negativ.size()!=b && negativ.size()>0)
            {
            k+=negativ.top();
            if(k<0)
                {
                cout<<-1;
                return 0;
                }
            poz.push(0);
            negativ.pop();
            }
        while(k-- && !poz.empty())
            {
            x=poz.top()*-1;poz.pop();
            poz.push((x+1)*-1);
            }
        }
    else
        {
        while(k-- && negativ.top()!=-1)
            {
            x=negativ.top();
            x++;
            negativ.push(x);
            negativ.pop();
            }
        if(negativ.top() == -1 && k>0)
            {
            cout<<-1;
            return 0;
            }
        }
    long long ans=1;
    while(!poz.empty())
        {
        ans = (ans * (-poz.top() % mod)) % mod;
        poz.pop();
        }
    while(!negativ.empty())
        {
        ans = (ans * (abs(negativ.top()) % mod)) % mod;
        negativ.pop();
        }
    cout<<ans;
    return 0;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base44/50
1Elfogadva0/01ms316 KiB
2Elfogadva0/01ms316 KiB
3Elfogadva0/01ms316 KiB
4Elfogadva0/01ms316 KiB
5Elfogadva0/04ms448 KiB
6Elfogadva2/21ms316 KiB
7Elfogadva2/21ms316 KiB
8Elfogadva2/21ms316 KiB
9Elfogadva2/22ms316 KiB
10Elfogadva2/27ms316 KiB
11Elfogadva2/274ms1036 KiB
12Elfogadva1/181ms1048 KiB
13Elfogadva1/12ms404 KiB
14Elfogadva1/18ms316 KiB
15Elfogadva1/117ms564 KiB
16Elfogadva1/143ms688 KiB
17Elfogadva1/118ms640 KiB
18Elfogadva1/114ms688 KiB
19Hibás válasz0/168ms960 KiB
20Hibás válasz0/128ms976 KiB
21Hibás válasz0/185ms948 KiB
22Elfogadva1/124ms944 KiB
23Elfogadva1/182ms892 KiB
24Elfogadva1/181ms1040 KiB
25Elfogadva2/22ms316 KiB
26Elfogadva2/27ms316 KiB
27Hibás válasz0/248ms712 KiB
28Hibás válasz0/148ms688 KiB
29Elfogadva2/219ms756 KiB
30Elfogadva1/172ms944 KiB
31Elfogadva1/135ms1036 KiB
32Elfogadva2/23ms316 KiB
33Elfogadva2/276ms984 KiB
34Elfogadva1/175ms1040 KiB
35Elfogadva2/278ms980 KiB
36Elfogadva2/272ms1028 KiB
37Elfogadva2/272ms940 KiB
38Elfogadva2/272ms988 KiB
39Elfogadva1/13ms316 KiB