2024/3/23 蓝桥杯

P1102 A-B 数对 二分

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

public class Main {
	public static void main(String[] args) {
		//A-B=C
		Scanner sc = new Scanner(System.in);
		int n = sc.nextInt();
		int C = sc.nextInt();
		int[] res = new int[n+1];
		for(int i=1;i<=n;i++) {
			res[i] = sc.nextInt();
		}
		
		Arrays.sort(res,1,n+1);//1
		long ans = 0;//2
		
		for(int i=1;i<=n;i++) {//枚举B
			
			int l1 = i,r1 = n;//二分A
			while(l1<r1) {
				int mid = (l1+r1)/2;
				if(res[mid]-res[i]>=C)	r1 = mid;
				else	l1 = mid+1;
			}
			
			int l2 = i,r2 = n;
			while(l2<r2) {
				int mid = (l2+r2+1)/2;
				if(res[mid]-res[i]<=C)	l2 = mid;
				else	r2 = mid-1;
			}
			
			if(res[l2] - res[i] == C) {
				ans+=(l2-l1)+1;
			}
		}
		System.out.println(ans);
	}
}

789. 数的范围 二分

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

public class Main {
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		int n = sc.nextInt();
		int k = sc.nextInt();
		int[] res = new int[n];
		for(int i=0;i<n;i++)
			res[i] = sc.nextInt();
		while(k--!=0) {
			int x = sc.nextInt();
			//先大于等于再小于等于
			int l1 = 0,r1 = n-1;
			while(l1<r1) {
				int mid1 = (l1+r1)/2;
				if(res[mid1]>=x) r1 = mid1;
				else	l1 = mid1+1;
			}
			if(res[l1] == x) {
				int l2 = 0,r2 = n-1;
				while(l2<r2) {
					int mid2 = (l2+r2+1)/2;
					if(res[mid2]<=x) l2 = mid2;
					else	r2 = mid2-1; 
				}
				System.out.println(l1+" "+l2);
			}else {
				System.out.println("-1 -1");
			}
		}
	}
}
相关推荐
YAy1717 分钟前
CC3学习记录
java·开发语言·学习·网络安全·安全威胁分析
代码小鑫18 分钟前
A035-基于Spring Boot的企业内管信息化系统
java·开发语言·spring boot·后端·spring
qq_35323353891 小时前
【原创】java+ssm+mysql校园疫情防控管理系统设计与实现
java·mvc·javaweb·ssm框架·bs·疫情防控
代码调试4 小时前
Springboot校园失物招领平台
java·spring boot
camellias_5 小时前
SpringBoot(二十三)SpringBoot集成JWT
java·spring boot·后端
tebukaopu1485 小时前
springboot如何获取控制层get和Post入参
java·spring boot·后端
昔我往昔5 小时前
SpringBoot 创建对象常见的几种方式
java·spring boot·后端
q567315235 小时前
用 PHP或Python加密字符串,用iOS解密
java·python·ios·缓存·php·命令模式
灭掉c与java5 小时前
第三章springboot数据访问
java·spring boot·后端
啊松同学6 小时前
【Java】设计模式——工厂模式
java·后端·设计模式