2024/3/23 蓝桥杯

P1102 A-B 数对 二分

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. 数的范围 二分

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");
			}
		}
	}
}

相关推荐

  1. 贪心+

    2024-03-25 21:54:04       45 阅读
  2. 简介

    2024-03-25 21:54:04       35 阅读
  3. 练习题

    2024-03-25 21:54:04       37 阅读
  4. :大写

    2024-03-25 21:54:04       21 阅读
  5. --平均

    2024-03-25 21:54:04       22 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-03-25 21:54:04       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-03-25 21:54:04       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-03-25 21:54:04       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-03-25 21:54:04       20 阅读

热门阅读

  1. Android--重构

    2024-03-25 21:54:04       21 阅读
  2. Python从入门到精通秘籍十八

    2024-03-25 21:54:04       18 阅读
  3. MySql Error Code:2006 - MySQL 服务器已离线问题解决

    2024-03-25 21:54:04       18 阅读
  4. 用汇编进行字符串匹配

    2024-03-25 21:54:04       18 阅读
  5. CentOS7.9安装MySQL5.7

    2024-03-25 21:54:04       17 阅读
  6. 五种主流数据库:分组统计

    2024-03-25 21:54:04       19 阅读
  7. VS实用快捷键小技巧

    2024-03-25 21:54:04       18 阅读
  8. 【C++】6-3 移动点的函数 分数 10

    2024-03-25 21:54:04       18 阅读
  9. Linux/Uinx 系统编程:定时器以及时钟同步

    2024-03-25 21:54:04       19 阅读
  10. springcloud 复习day2~[条件装配]

    2024-03-25 21:54:04       17 阅读
  11. 【Caddy】Caddy实践1——此网站无法提供安全连接

    2024-03-25 21:54:04       18 阅读
  12. 将表格数据导出 Excel 格式的数据方法(2)

    2024-03-25 21:54:04       21 阅读
  13. ruoyi-nbcio-plus后端里mapstruct-plus和lombok的使用

    2024-03-25 21:54:04       17 阅读