246442026-02-13 09:01:57szjMaximális szorzat (50 pont)cpp11Hibás válasz 13/5059ms2760 KiB
#include <bits/stdc++.h>
#define ll long long
#define blugy %1000000007
using namespace std;
class cucc
{
public:
    bool operator()(const ll &x, const ll &y)const
    {
        return x < y;
    }
};
int main()
{
    //ifstream cin("f.txt");
    ios::sync_with_stdio(0);
    cin.tie(0);
    ll n, k, b, i, a, sum=1, parsum=0, el;
    cin >> n >> k >> b;
    bool cuccli=0;
    priority_queue<ll, vector<ll>, cucc> nega;
    priority_queue<ll, vector<ll>, greater<ll>> pozi;
    for(i=0; i<n; i++)
    {
        cin >> a;
        if(a<0)nega.push(a);
        else pozi.push(a);
    }
    if(b>nega.size())
    {
        cout <<-1;
        return 0;
    }
    while(nega.size()>b)
    {
        k+=nega.top();
        nega.pop();
        pozi.push(0);
    }
    if(k<0)
    {
        cout << -1;
        return 0;
    }
    if(pozi.empty())
    {
        while(!nega.empty())
        {
            pozi.push(nega.top());
            nega.pop();
            cuccli=1;
        }
    }
    if(!pozi.empty())
    {
        while(k!=0)
        {
            a = pozi.top();
            if(a+1>=0)
            {
                cout << -1;
                return 0;
            }
            pozi.pop();
            pozi.push(a+1);
            k--;
        }
    }
    while(!pozi.empty())
    {
        sum=(sum*(abs(pozi.top())blugy))blugy;
        pozi.pop();
    }
    while(!nega.empty())
    {
        sum=(sum*(abs(nega.top()))blugy)blugy;
        nega.pop();
    }
    cout << sum;
    return 0;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base13/50
1Hibás válasz0/01ms316 KiB
2Hibás válasz0/01ms316 KiB
3Hibás válasz0/01ms508 KiB
4Hibás válasz0/01ms508 KiB
5Hibás válasz0/02ms564 KiB
6Hibás válasz0/21ms500 KiB
7Hibás válasz0/21ms316 KiB
8Hibás válasz0/21ms316 KiB
9Hibás válasz0/21ms436 KiB
10Hibás válasz0/23ms564 KiB
11Hibás válasz0/217ms1596 KiB
12Hibás válasz0/117ms1456 KiB
13Hibás válasz0/11ms508 KiB
14Hibás válasz0/12ms504 KiB
15Elfogadva1/18ms884 KiB
16Hibás válasz0/18ms1036 KiB
17Elfogadva1/18ms944 KiB
18Elfogadva1/16ms948 KiB
19Elfogadva1/157ms2588 KiB
20Elfogadva1/152ms2532 KiB
21Elfogadva1/159ms2716 KiB
22Elfogadva1/121ms2760 KiB
23Hibás válasz0/118ms1184 KiB
24Hibás válasz0/117ms1536 KiB
25Hibás válasz0/22ms316 KiB
26Hibás válasz0/22ms564 KiB
27Elfogadva2/235ms1440 KiB
28Elfogadva1/134ms1468 KiB
29Elfogadva2/28ms1012 KiB
30Hibás válasz0/118ms1468 KiB
31Elfogadva1/114ms1580 KiB
32Hibás válasz0/21ms316 KiB
33Hibás válasz0/218ms1452 KiB
34Hibás válasz0/118ms1400 KiB
35Hibás válasz0/217ms1456 KiB
36Hibás válasz0/218ms1464 KiB
37Hibás válasz0/217ms1460 KiB
38Hibás válasz0/218ms1456 KiB
39Hibás válasz0/11ms316 KiB