Run ID 作者 问题 语言 测评结果 分数 时间 内存 代码长度 提交时间
38573 stevenyu 【J】T4 C++ 解答错误 60 69 MS 1816 KB 905 2025-10-16 20:47:30

Tests(6/10):


#include<bits/stdc++.h> using namespace std; #define int long long int n,A,cf,cm,m,sum[100005]; int a[100005],cnt; int ans; inline bool check(int mii,int mi){ if(m==0)return false; int l=1,r=mi; while(l<r){ int mid=(l+r+1)>>1; if(a[mid]>mii)r=mid-1; else l=mid; } return m>=mii*r-sum[r]; } signed main(){ cin>>n>>A>>cf>>cm>>m; for(int i=1;i<=n;i++){ cin>>a[i]; if(a[i]==A)cnt++; } sort(a+1,a+n+1); int tm=m; for(int i=1;i<=n;i++){ sum[i]=sum[i-1]+a[i]; } for(int i=n;i>=1;i--){ if(m<=0)break; if(a[i]==A)continue; if(m>=(A-a[i])){ m-=(A-a[i]); a[i]=A; if(i==1){ ans=max(ans,A*cm+n*cf); break; } int l=a[1],r=A-1; while(l<r){ int mid=(l+r+1)>>1; if(!check(mid,i-1))r=mid-1; else l=mid; } ans=max(ans,l*cm+(n-i+1)*cf); } else break; } cout<<ans; return 0; }


测评信息: