标签:Salary int 工资 ll codeforces long Changing 500010 include
题意:给你n个人,和s块钱,每个人都有一个工资区间,你给所有人都发工资。然后要他们工资的中位数最大。
思路:二分找那个值。那个值要满足至少有n/2+1个工资区间内。
#include<cstdio> #include<cstring> #include<queue> #include<cmath> #include<algorithm> #include<map> #include<vector> #include<string> #include<set> #define ll long long using namespace std; int l[500010]; int r[500010]; int n; ll s; int check(int md) { int k=(n+1)/2; vector<int> M; for(int i=1;i<=n;i++) { int v=max(l[i],md); if(r[i]<v) continue; M.push_back(v-l[i]); } if((int)M.size()<k) return 0; ll sum=0; sort(M.begin(),M.end()); for(int i=0;i<k;i++) sum+=M[i]; return sum<=s; } int main() { int t; scanf("%d",&t); while(t--) { scanf("%d%lld",&n,&s); for(int i=1;i<=n;i++) { scanf("%d%d",&l[i],&r[i]); s-=l[i]; } int st=0,ed=1e9; while(st<ed) { int md=(st+ed+1)/2; if(check(md)) { st=md; } else ed=md-1; } printf("%d\n",st); } }
标签:Salary,int,工资,ll,codeforces,long,Changing,500010,include 来源: https://www.cnblogs.com/2462478392Lee/p/11745286.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。