2024/3/24 蓝桥杯

P1678 烦恼的高考志愿 二分

java 复制代码
import java.util.Arrays;
import java.util.Scanner;

public class Main {
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		int n = sc.nextInt();
		int m = sc.nextInt();
		int[] a = new int[n+1];//学校
		int[] b = new int[m+1];//学生
		for(int i=1;i<=n;i++) {
			a[i] = sc.nextInt();
		}
		for(int i=1;i<=m;i++) {
			b[i] = sc.nextInt();
		}
		Arrays.sort(a,1,n+1);
		Arrays.sort(b,1,m+1);
		
		long sum = 0;
		for(int i=1;i<=m;i++) {//枚举学生
			int l = 1, r = n;
			while(l<r) {
				int mid = (l+r)/2;
				if(a[mid]>=b[i]) r = mid;
				else l = mid+1;
			}//找到第一个大于等于学生分数的学校
			if(l == 1)
				sum+=a[1]-b[i];
			if(l>=2)
				sum+=Math.min(Math.abs(a[l]-b[i]),Math.abs(a[l-1]-b[i]));
		}
		System.out.println(sum);
	}
}
相关推荐
一 乐8 小时前
高校评教|基于SpringBoot+vue高校学生评教系统 (源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·学习
自在极意功。8 小时前
手写Tomcat:深入理解Servlet容器工作原理
java·servlet·tomcat·socket
Boop_wu8 小时前
[Java EE] 字符流和字节流实例
java·开发语言·apache
是一个Bug8 小时前
Spring事件监听器在电商订单系统中的应用
java·python·spring
Arva .8 小时前
讲一下 Spring 中用到的设计模式
java·spring·设计模式
bbq粉刷匠8 小时前
Java-顺序表
java
小白程序员成长日记8 小时前
2025.12.03 力扣每日一题
算法·leetcode·职场和发展
Tan_Ying_Y9 小时前
Mybatis的mapper文件中#和$的区别
java·tomcat·mybatis
难以触及的高度9 小时前
Java for循环完全指南:从基础到高性能实践
java·开发语言