171152025-05-23 17:30:53ercseferencMaximális szorzat (50 pont)cpp17Hibás válasz 43/5059ms804 KiB
#include <bits/stdc++.h>
using namespace std;
int main()
{
    int n,b; long long k; //ifstream f("szamok.txt");
    cin>>n>>k>>b; vector<int>a(n);
    for(int i=0; i<n; i++)cin>>a[i];
    sort(a.begin(),a.end());
    if(b!=0 && a[b-1]>=0){cout<<-1; return 0;}
    long long s=0,t=b;
    if(n!=b){
        while(k>s+(a[t]-a[t-1])*(t-b) && t<n){
            s+=(a[t]-a[t-1])*(t-b);
            t++;}
        for(int i=b; i<t; i++)a[i]=a[t-1];
        k-=s;
        for(int i=b; i<t; i++)a[i]+=k/(t-b);
        k=k%(t-b);
        for(int i=b; i<b+k; i++)a[i]++;
        if(a[b]<0){cout<<-1; return 0;}}
    else{
        int r=1;
        while(k-(r+1)*(a[r]-a[r-1])>=0){
            k-=(r+1)*(a[r]-a[r-1]); r++;}
        for(int i=0; i<r; i++)a[i]=a[r];
        for(int i=0; i<=r; i++)a[i]+=k/(r+1);
        k=k%(r+1);
        for(int i=0; i<k; i++)a[i]++;
        if(a[n-1]>=0){cout<<-1; return 0;}}
    //for(int i=0; i<n; i++)cout<<a[i]<<" ";
    s=1; int mod=1000000007;
    for(int i=0; i<n; i++)s=(s*a[i])%mod;
    cout<<s;
    return 0;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base43/50
1Elfogadva0/01ms316 KiB
2Elfogadva0/01ms316 KiB
3Elfogadva0/01ms316 KiB
4Elfogadva0/01ms316 KiB
5Elfogadva0/04ms508 KiB
6Elfogadva2/21ms316 KiB
7Elfogadva2/21ms316 KiB
8Elfogadva2/21ms316 KiB
9Elfogadva2/21ms316 KiB
10Elfogadva2/24ms436 KiB
11Elfogadva2/252ms564 KiB
12Elfogadva1/154ms564 KiB
13Elfogadva1/11ms316 KiB
14Elfogadva1/14ms316 KiB
15Elfogadva1/119ms604 KiB
16Elfogadva1/121ms756 KiB
17Elfogadva1/119ms564 KiB
18Elfogadva1/19ms608 KiB
19Hibás válasz0/139ms564 KiB
20Hibás válasz0/128ms564 KiB
21Hibás válasz0/159ms564 KiB
22Futási hiba0/123ms804 KiB
23Elfogadva1/157ms756 KiB
24Elfogadva1/156ms564 KiB
25Elfogadva2/21ms500 KiB
26Elfogadva2/24ms316 KiB
27Hibás válasz0/228ms748 KiB
28Hibás válasz0/128ms564 KiB
29Elfogadva2/221ms568 KiB
30Elfogadva1/157ms800 KiB
31Elfogadva1/141ms804 KiB
32Elfogadva2/21ms316 KiB
33Elfogadva2/257ms616 KiB
34Elfogadva1/157ms764 KiB
35Elfogadva2/257ms800 KiB
36Elfogadva2/257ms756 KiB
37Elfogadva2/257ms804 KiB
38Elfogadva2/257ms800 KiB
39Elfogadva1/11ms316 KiB