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);
	}
}
相关推荐
元气满满-樱2 分钟前
Tomcat理论
java·tomcat
一只叫煤球的猫6 分钟前
从夯到拉,锐评13个Java Web框架
java·后端·程序员
小南家的青蛙13 分钟前
LeetCode第1261题 - 在受污染的二叉树中查找元素
算法·leetcode·职场和发展
heartbeat..14 分钟前
JUC 在实际业务场景的落地实践
java·开发语言·网络·集合·并发
tryxr14 分钟前
线程安全的类 ≠ 线程安全的程序
java·开发语言·vector·线程安全
rchmin24 分钟前
Java内存模型(JMM)详解
java·开发语言
Wpa.wk31 分钟前
Tomcat的安装与部署使用 - 说明版
java·开发语言·经验分享·笔记·tomcat
吧啦蹦吧36 分钟前
java.lang.Class#isAssignableFrom(Class<?> cls)
java·开发语言
都是蠢货44 分钟前
drop delete和truncate的区别?
java·开发语言
凤凰战士芭比Q1 小时前
Nexus仓库(maven仓库、Yum仓库、APT仓库)
java·maven