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);
	}
}
相关推荐
东坡白菜3 小时前
破局全栈:一个前端开发的Java入门实战记录(1)
java·全栈
唐青枫3 小时前
Java Tomcat 实战指南:从 Servlet 容器到 Spring Boot 部署
java
wsaaaqqq3 小时前
roudan:自由选择实体、灵活操作数据、快速写入数据库的 Java 框架
java
plainGeekDev7 小时前
null 判断 → Kotlin 可空类型
android·java·kotlin
糖拌西瓜皮7 小时前
Java开发者视角:深入理解Node.js异步编程模型
java·后端·node.js
plainGeekDev7 小时前
getter/setter → Kotlin 属性
android·java·kotlin
一线大码7 小时前
Smart-Doc 的简单使用
java·后端·restful
MacroZheng9 小时前
Claude Code官方桌面端正式发布,夯爆了!
java·人工智能·后端
虚无境9 小时前
如何编写一个SpringBoot项目告警推送的Starter
java·prometheus·webhook