Atcoder ABC338 E - Chords

Chords(和弦)

时间限制:2s 内存限制:1024MB

【原题地址】

所有图片源自Atcoder,题目译文源自脚本Atcoder Better!

点击此处跳转至原题

【问题描述】

【输入格式】

【输出格式】

【样例输入】

样例一、

java 复制代码
3
1 3
4 2
5 6

样例二、

java 复制代码
3
6 1
4 3
2 5

【样例输出】

样例一、

java 复制代码
Yes

样例二、

java 复制代码
No

【样例说明1】


【样例说明2】


【解题思路】

老汉使用到的是运用队列辅助的解题方式

本题在圆上的直线可以看作为一个从1点到2n点的直线上的区间,求圆上直线是否相交可以看成直线上区间是否相交,如下图所示:

将每一对区间最小值视作左端点,最大值视作右端点,我们可以发现当区间不相交时位于当前左端点右方且距离最近的右端点是与之成对的,当相交时,这个右端点是不与之成对的,我们需要运用队列进行操作,从1点开始向2n点前进,如果是左端点,将该点存入队列,是右端点时,该右端点与队尾元素的左端点是同一区间时,删除队尾元素,继续对下一点进行操作,不是同一区间时,代表区间相交,结束判断,输出答案Yes,全部判断完未发现区间相交,输出答案No。

代码注释有详细过程

【代码】

java 复制代码
package ABC338_E_Chords;

import java.util.LinkedList;
import java.util.Scanner;

public class Main {
	public static void main(String[] args) {
		Scanner scan = new Scanner(System.in);
		int n = scan.nextInt();
		// 判断当前点是否为区间左端
		boolean[] isleft = new boolean[2 * n + 1];
		// 存放对应左端的成对次序
		int[] left = new int[2 * n + 1];
		// 存放对应右端的成对次序
		int[] right = new int[2 * n + 1];

		for (int i = 1; i < n + 1; i++) {
			int a = scan.nextInt();
			int b = scan.nextInt();
			// 将这一对连线的最小值作为左端点,最大值作为右端点,并对对应的isleft赋值
			if (a < b) {
				left[a] = i;
				right[b] = i;
				isleft[a] = true;
			} else {
				left[b] = i;
				right[a] = i;
				isleft[b] = true;
			}
		}
		// 是否符合条件的情况,即是否有交点
		boolean yes = false;
		// 运用队列进行存储
		LinkedList<Integer> q = new LinkedList<Integer>();
		for (int i = 1; i < 2 * n + 1; i++) {
			// 当当前点为左端点时,将对应次序加入队列
			if (isleft[i]) {
				q.add(left[i]);
			} else {
				// 当当前点为右端点时,判断队尾是否与当前右端点次序相同,即成对
				if (right[i] == q.peekLast()) {
					// 相同则删除队尾元素
					q.pollLast();
				} else {
					// 不相同则代表相交,结束判断
					yes = true;
					break;
				}
			}
		}
		// 根据对应结果进行输出
		if (yes) {
			System.out.println("Yes");
		} else {
			System.out.println("No");
		}
		scan.close();
	}
}
相关推荐
2302_809798323 分钟前
【JavaWeb】Docker项目部署
java·运维·后端·青少年编程·docker·容器
网安INF27 分钟前
CVE-2020-17519源码分析与漏洞复现(Flink 任意文件读取)
java·web安全·网络安全·flink·漏洞
一叶知秋哈27 分钟前
Java应用Flink CDC监听MySQL数据变动内容输出到控制台
java·mysql·flink
jackson凌32 分钟前
【Java学习笔记】SringBuffer类(重点)
java·笔记·学习
sclibingqing38 分钟前
SpringBoot项目接口集中测试方法及实现
java·spring boot·后端
程序员JerrySUN42 分钟前
全面理解 Linux 内核性能问题:分类、实战与调优策略
java·linux·运维·服务器·单片机
糯米导航1 小时前
Java毕业设计:办公自动化系统的设计与实现
java·开发语言·课程设计
糯米导航1 小时前
Java毕业设计:WML信息查询与后端信息发布系统开发
java·开发语言·课程设计
米粉03051 小时前
深入剖析Nginx:从入门到高并发架构实战
java·运维·nginx·架构
简诚1 小时前
HttpURLConnection实现
java