洛谷 P2782 友好城市 线性DP 最长上升子序列 二分查找 lower_bound

news/2024/10/17 20:32:29/

🍑 算法题解专栏


🍑 洛谷:友好城市

题目描述

有一条横贯东西的大河,河有笔直的南北两岸,岸上各有位置各不相同的N个城市。北岸的每个城市有且仅有一个友好城市在南岸,而且不同城市的友好城市不相同。每对友好城市都向政府申请在河上开辟一条直线航道连接两个城市,但是由于河上雾太大,政府决定避免任意两条航道交叉,以避免事故。编程帮助政府做出一些批准和拒绝申请的决定,使得在保证任意两条航道不相交的情况下,被批准的申请尽量多。

输入格式

第1行,一个整数N,表示城市数。

第2行到第n+1行,每行两个整数,中间用一个空格隔开,分别表示南岸和北岸的一对友好城市的坐标。

输出格式

仅一行,输出一个整数,表示政府所能批准的最多申请数。

样例 #1

样例输入 #1

7
22 4
2 6
10 3
15 12
9 8
17 17
4 2

样例输出 #1

4

提示

50% 1<=N<=5000,0<=xi<=10000

100% 1<=N<=2e5,0<=xi<=1e6


🍑 题意

🍤 每个城市只能建立一座桥
🍤 桥不能交叉:

🍑 Arrays.BinarySort(数组,起点,终点(不包含),待查找的值)
👨‍🏫 参考文档

在这里插入图片描述
🍑 insert point(插入点)

🍤 初始化
数组 a {1,3,5,7}
查找值:4 
🍤 实测出真知
BinarySort(a,4) == -3
设 insert point 为 x
则 -x - 1 = -3  --> x = -(-3 + 1) = 3
👨‍🏫 为什么插入点是 3 呢
假设:4 已经插入到数组了,则 a = {1,3,4,5,7}
可见:第一个大于 4 的元素5 的下标为 

🍑 输入数据量过多,使用快读
🍑 扩展:C++ STL 中的 lower_bound 参考

有序的情况下,lower_bound返回指向第一个值不小于val的位置
也就是返回第一个大于等于val值的位置。(通过二分查找)

🍑 AC代码

import java.io.*;
import java.util.*;public class Main
{static int N = 200010;static Pair[] a = new Pair[N];static int[] f = new int[N]; // f[i]=长度为i的IS最小最后一个数static BufferedReader in = new BufferedReader(new InputStreamReader(System.in));//	友好城市类static class Pair{int l, r;Pair(int l, int r){this.l = l;this.r = r;}}//	在数组中找到 >= x 的所有数中的最小值(下标) // 手动实现 lowerBoundstatic int binarySearch(int[] a, int l, int r, int x){while (l < r){int m = l + r >> 1;if (a[m] < x)l = m + 1;else{r = m;}}return l;
//		if (l == r)
//			return l;
//		int m = l + r + 1 >> 1;
//		if (x > a[m])// m 符合条件,结果在右区间
//			return binarySearch(a, m, r, x);
//		else// m 不符合条件,结果在左区间
//		{
//			return binarySearch(a, l, m - 1, x);
//		}}public static void main(String[] args) throws IOException{
//		Scanner sc = new Scanner(System.in);
//		int n = sc.nextInt();int n = Integer.parseInt(in.readLine());int p = 0;for (int i = 0; i < n; i++){String[] ss = in.readLine().split(" ");int l = Integer.parseInt(ss[0]);int r = Integer.parseInt(ss[1]);//			int l = sc.nextInt();
//			int r = sc.nextInt();a[i] = new Pair(l, r);}Arrays.sort(a, 0, n, (o1, o2) -> o1.l - o2.l);for (int i = 0; i < n; i++){if (a[i].r > f[p]){p++;f[p] = a[i].r;} else{
//				int pos = Arrays.binarySearch(f, 1, p + 1, a[i].r);// ACint pos = binarySearch(f, 1, p, a[i].r); //手动实现if (pos < 0)// 加一层保险pos = -(pos + 1);// 本题保证了城市不会重复,所以可以直接按返回 -(插入点-1) 处理f[pos] = a[i].r;}}System.out.println(p);}
}

🍑 暴力线性DP O(n^2) (50%)

import java.util.Arrays;
import java.util.Scanner;public class Main
{static int N = (int) 2e5 + 10;static Pair[] w = new Pair[N];static int[] f = new int[N];static class Pair{int x;int y;public Pair(int x, int y){super();this.x = x;this.y = y;}}public static void main(String[] args){Scanner sc = new Scanner(System.in);int n = sc.nextInt();for (int i = 0; i < n; i++){int x = sc.nextInt();int y = sc.nextInt();w[i] = new Pair(x, y);}Arrays.sort(w, 0, n, (o1, o2) -> o1.y - o2.y);//		DPint res = 0;for (int i = 0; i < n; i++){f[i] = 1;for (int j = 0; j < i; j++)if (w[j].x < w[i].x)f[i] = Math.max(f[i], f[j] + 1);res = Math.max(res, f[i]);}System.out.println(res);}
}

http://www.ppmy.cn/news/59376.html

相关文章

供应链 | 需求不确定情况下的物料需求规划: 基于随机优化的研究

作者&#xff1a;Simon Thevenin, Yossiri Adulyasak, Jean-Francois Cordeau​ 引用&#xff1a;Thevenin S, Adulyasak Y, Cordeau J F. Material requirements planning under demand uncertainty using stochastic optimization[J]. Production and Operations Management,…

汇编三、51单片机汇编指令1

1、指令格式 (1)举例&#xff1a;将立即数0x30送入累加器A MOV  A, #0x30 标号 操作码 目标地址&#xff0c;数据源 ;注解 (2)标号&#xff0c;注解可选项&#xff0c;不一定有。 2、指令执行时间和指令存储空间 (1)指令执…

解决Matlab在Linux下无法使用hardware OpenGL的问题

解决Matlab在Linux下无法使用hardware OpenGL的问题 1 报错信息 在命令行使用命令matlab -nodesktop -nosplash启动Matlab时&#xff0c;出现如下报错&#xff1a; MATLAB is selecting SOFTWARE OPENGL rendering.在查阅ArchWiki Matlab OpenGL Acceleration栏目后&#xf…

麓言信息设计师作品集从0到5怎么做才能顺利找到工作?

作品集整体定位与风格设计最近我在看室内设计的案例&#xff0c;有中式、北欧、现代、轻奢、美式、地中海等等&#xff0c;通过这些风格描述相比大家对风格有了一定的印象&#xff0c;那么如果让你设计自己的作品集&#xff0c;你是否可以让他有属于你自己的风格呢&#xff1f;…

深入了解在 AWS 中存储应用程序参数的最佳方式

许多应用程序现在托管在公共云平台上&#xff0c;因此必须利用云来存储其数据和应用程序参数。在最受欢迎的云提供商中&#xff0c;亚马逊网络服务&#xff08;AWS&#xff09;是使用最广泛的。虽然 AWS 提供了许多用于存储应用程序参数的解决方案&#xff0c;但了解哪个选项最…

利用通信基础设施提高电网的稳态稳定性(Matlab代码实现)

目录 1 概述 2 稳态稳定性分析 2.1 系统模型 2.2 稳态稳定性 2.3 问题说明 3 仿真结果 4 Matlab代码 1 概述 随着电力系统的复杂性和规模的增加&#xff0c;电力系统的有效控制变得越来越困难。我们提出了一种自动控制策略&#xff0c;该策略基于通过通信基础设施获得的…

Java 基础进阶篇(四)—— 权限修饰符、final 关键字与枚举

文章目录 一、权限修饰符二、final 关键字2.1 final 作用2.2 final 修饰变量举例2.3 常量 三、枚举3.1 枚举的格式3.2 枚举的特征3.3 枚举的应用 一、权限修饰符 权限修饰符 用于约束成员变量、构造器、方法等的访问范围。 权限修饰符&#xff1a; 有四种作用范围由小到大 (p…

一起单测引起的项目加载失败惨案 | 京东云技术团队

作者&#xff1a;京东科技 宋慧超 一、前言 最近在开发一个功能模块时&#xff0c;在功能自测阶段&#xff0c;通过使用单测测试功能的完整性&#xff0c;在测试单测联通性使用到静态方法测试时&#xff0c;发现单测报错&#xff0c;通过查阅解决方案发现需要对Javaassist包进…