解题思路:
一.定义sum数组用来存刷题数小于i的人数
运用前缀和
二.
如果小于i题的人数小于大于i题的人数
那么必须在刷i+1,max题里找,看看到底刷到多少题才能躺的人大于等于卷的人
如果大于等于则不需要再刷了,值为0
注意事项:
参考代码:
import java.io.*; import java.util.*; /** * @Author:杨雨彤 * @date:2024/2/5 17:02 */ public class Main{ static BufferedReader br=new BufferedReader(new InputStreamReader(System.in)); static PrintWriter pw=new PrintWriter(new OutputStreamWriter(System.out)); static int sum[]; static int n; static int max; static int min; public static void main(String[] args) throws IOException { n=Integer.parseInt(br.readLine()); sum=new int[100020]; int []need=new int[n]; int []ans=new int[n]; int max=-1; int min=Integer.MAX_VALUE; String[] s = br.readLine().split(" "); int index; for (int i = 0; i < n; i++) { index=Integer.parseInt(s[i]); ans[i]=index; max=Math.max(max,index); min=Math.min(min,index); sum[index]++; } //sum[i]记录刷题数少于等于i题的人数,故sum[i-1]就是刷题数量小于i题的人数 //前缀和 for (int j =min+1; j <=max ; j++) { sum[j] = sum[j - 1] + sum[j] ; } for (int i= 0; i <n ; i++) { if(ans[i]<1){ need[i]=0; }else if (sum[ans[i]-1]<n-sum[ans[i]]){ int target = binSearch(ans[i]+1, max); need[i]=target-ans[i]; } } // for (int i = 0; i <n ; i++) { pw.print(need[i]+" "); } pw.flush(); pw.close(); } private static int binSearch(int l,int r){ int res=Integer.MAX_VALUE; while(l<=r){ int mid=(l+r)>>1; if(sum[mid-1]-1>=n-sum[mid]){//这里我们是想让这个人的成绩ans[i]变成mid,故在找刷题数小于mid题时要把这个人删去 res=Math.min(res,mid); r=mid-1; }else{ l=mid+1; } } return res; } }
0.0分
2 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复