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");
			}
		}
	}
}
相关推荐
曳渔5 分钟前
UDP/TCP套接字编程简单实战指南
java·开发语言·网络·网络协议·tcp/ip·udp
hqxstudying36 分钟前
JAVA项目中邮件发送功能
java·开发语言·python·邮件
最初的↘那颗心40 分钟前
Java HashMap深度解析:原理、实现与最佳实践
java·开发语言·面试·hashmap·八股文
小兔兔吃萝卜1 小时前
Spring 创建 Bean 的 8 种主要方式
java·后端·spring
亲爱的马哥1 小时前
重磅更新 | 填鸭表单TDuckX2.9发布!
java
Java中文社群1 小时前
26届双非上岸记!快手之战~
java·后端·面试
whitepure1 小时前
万字详解Java中的面向对象(二)——设计模式
java·设计模式
whitepure1 小时前
万字详解Java中的面向对象(一)——设计原则
java·后端
2301_793086872 小时前
SpringCloud 02 服务治理 Nacos
java·spring boot·spring cloud
回家路上绕了弯2 小时前
MySQL 详细使用指南:从入门到精通
java·mysql