解题思路:

一.定义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.0分

2 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论