UVa1359/LA3491 Hills

题目链接

         本题是2005年ICPC亚洲区域赛杭州欧赛区的H题

题意

        平面上有 n(n≤500)条线段,其中每条线段的端点都不会在其他线段上。你的任务是数一数有多少个“没有被其他线段切到”的三角形(即小山)。如下图所示,虽然有两个三角形,但其中一个被切到了,所以答案是1。

分析

        将每条线段作为两条有向线段做预处理:依次与其他线段求交点(用分数保存叉乘比值)同时保存逆时针夹角的余弦值,最后对多线段交于同一点时保留余弦值最小的那一段。

        预处理后,遍历并计数:依次遍历有向线段的每一最小分段,当恰好时三条不同线段的最小分段形成环时计数+1。答案是计数结果除以3。

AC代码

#include <iostream>
#include <cmath>
#include <algorithm>
using namespace std;#define N 504
int x[N], y[N], vx[N], vy[N], c[2][N], n; double l[N];
struct frac {int p, q;bool operator== (const frac& rhs) const {return p*(long long)rhs.q - q*(long long)rhs.p == 0;}
};struct je {frac f, e; double t; int i;bool operator< (const frac& r) const {return f.p*(long long)r.q - f.q*(long long)r.p < 0;}bool operator< (const je& rhs) const {return f.p*(long long)rhs.f.q - f.q*(long long)rhs.f.p < 0;}
} a[2][N][N];void merge(je (&a)[N], int &c) {sort(a, a+c);int k = 0;for (int j=1; j<c; ++j) {if (a[k] < a[j]) a[++k] = a[j];else if (a[j].t < a[k].t) a[k].e = a[j].e, a[k].t = a[j].t, a[k].i = a[j].i;}c = ++k;
}int solve() {cin >> n;for (int i=0; i<n; ++i) {cin >> x[i] >> y[i] >> vx[i] >> vy[i];c[0][i] = c[1][i] = 0; vx[i] -= x[i]; vy[i] -= y[i];l[i] = sqrt(vx[i]*vx[i] + vy[i]*vy[i]);}for (int i=0; i<n; ++i) {for (int j=i+1; j<n; ++j) {int ux = x[i] - x[j], uy = y[i] - y[j];int p1 = vx[j]*uy - ux*vy[j], p2 = vx[i]*uy - ux*vy[i], q0 = vx[i]*vy[j] - vx[j]*vy[i], q = q0;if (q < 0) p1 = -p1, p2 = -p2, q = -q;if (p1 < 0 || p1 > q || p2 < 0 || p2 > q) continue;double t = (vx[i]*vx[j] + vy[i]*vy[j]) / l[i] / l[j];je &ef = a[0][i][c[0][i]++], &eb = a[1][i][c[1][i]++], &ff = a[0][j][c[0][j]++], &fb = a[1][j][c[1][j]++];ef.f.q = eb.f.q = ff.f.q = fb.f.q = q; ef.f.p = p1; eb.f.p = q-p1; ff.f.p = p2; fb.f.p = q-p2;if (q0 > 0) {ef.e = ff.f; eb.e = fb.f; ef.t = eb.t = t; ef.i = j; eb.i = j+n;ff.e = eb.f; fb.e = ef.f; ff.t = fb.t = -t; ff.i = i+n; fb.i = i;} else {ef.e = fb.f; eb.e = ff.f; ef.t = eb.t = -t; ef.i = j+n; eb.i = j;ff.e = ef.f; fb.e = eb.f; ff.t = fb.t = t; ff.i = i; fb.i = i+n;}}merge(a[0][i], c[0][i]); merge(a[1][i], c[1][i]);}int s = 0;for (int i=0; i<n; ++i) for (int j=0; j<2; ++j) for (int k=1; k<c[j][i]; ++k) {je &e = a[j][i][k]; int r = e.i < n ? 0 : 1, m = e.i < n ? e.i : e.i-n, t = c[r][m];je (&p)[N] = a[r][m]; int x = lower_bound(p, p+t, e.e) - p + 1;if (x == t) continue;je &b = p[x]; r = b.i < n ? 0 : 1; m = b.i < n ? b.i : b.i-n; t = c[r][m];je (&u)[N] = a[r][m]; x = lower_bound(u, u+t, b.e) - u + 1;if (x < t && u[x].i == j*n+i && u[x].e == a[j][i][k-1].f) ++s;}return s / 3;
}int main() {int t; cin >> t;for (int kase=1; kase<=t; ++kase) {cout << "Case " << kase << ':' << endl << solve() << endl;if (kase < t) cout << endl;}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/688606.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Vitis】Vitis性能优化的开源库

Vitis HLS简介 Vitis™HLS是一种高层次综合工具&#xff0c;支持将C、C和OpenCL™函数硬连线到器件逻辑互连结构和RAM/DSP块上。 Vitis HLS可在Vitis应用加速开发流程中实现硬件内核&#xff0c;并使用C/C语言代码在VivadoDesign Suite中为赛灵思器件设计开发RTL IP。 【Vitis…

sqlserver 分组查询

在 SQL Server 中&#xff0c;分组查询是指使用 GROUP BY 子句对查询结果进行分组&#xff0c;并对每个组应用聚合函数&#xff08;如 SUM、COUNT、AVG 等&#xff09;以计算每个组的汇总值。 以下是一个基本的分组查询示例&#xff1a; SELECT 列1, 列2, 聚合函数(列3) FROM…

不坑盒子 助力高效办公的Office插件

不坑盒子简介 很多朋友在工作过程中需要对Word文档进行编辑处理&#xff0c;如果想让Word排版更有效率可以试试小编带来的这款不坑盒子软件&#xff0c;是一个非常好用的办公工具&#xff0c;拥有近百项功能的Word&#xff0c;wps插件&#xff0c;支持Office 2010以上的版本&a…

【plt.bar绘制条形图or柱状图】:从入门到精通,只需一篇文章!【Matplotlib可视化】

【&#x1f4ca;plt.bar绘制条形图】&#xff1a;从入门到精通&#xff0c;只需一篇文章&#xff01;【Matplotlib】 利用Matplotlib进行数据可视化示例 &#x1f335;文章目录&#x1f335; &#x1f50d; 一、初识plt.bar&#xff1a;条形图的基本概念&#x1f4a1; 二、plt.…

Maven - Plugins报错的正确解决之道

背景&#xff1a; 正确解决之道&#xff1a; 在自己本地Maven的安装目录中找到自己的仓库地址目录&#xff1a;直接搜索自己报错的插件文件&#xff0c;把它们删除&#xff0c;如图&#xff1a; 接着回到IDEA点击Maven刷新按钮重新加载即可&#xff1a;已解决 反例&#xff1…

使用pycaw检测微信消息提示

使用pycaw检测微信消息提示 利用pywinauto库&#xff0c;我们确实可以实现在社交软件上的自动接收与发送消息功能。但要精确捕捉新消息的到达时机&#xff0c;这一库显得稍显笨拙。 这种方法虽然实用&#xff0c;但在效率上可能不是最优选择。 新消息的来到不仅仅有消息记录的…

Swagger-的使用

Swagger-的使用 前言效果1、相关依赖2、相关注解2.1 @Tag设置整个类的名称和详情2.2 @Operation描述具体的方法2.3 @Parameter 描述参数2.4@Schema 为属性添加注释3、Docket配置3.1通过gropeediopenapi进行分组3.2 通过docsOpenApi设置前言 在我们和前端进行交互的时候,出接口…

【机构vip教程】Appium自动化(2):Python+Appium环境搭建

windows下搭建pythonappium环境 搭建过程步骤如下&#xff1a; 1、安装jdk并配置好环境变量&#xff08;jdk版本1.8以上&#xff09; 2、安装android-sdk并配置好环境变量&#xff1b;具体步骤见&#xff1a;https://www.cnblogs.com/YouJeffrey/p/15243705.html 3、安装安…

浅谈js事件机制

事件是什么&#xff1f;事件模型&#xff1f; 原始事件模型&#xff08;DOM0级&#xff09; HTML代码中指定属性值&#xff1a;在js代码中指定属性值&#xff1a;优点&#xff1a;缺点&#xff1a; IE 事件模型DOM2事件模型 对事件循环的理解 宏任务&#xff08;Macrotasks&…

Three.JS教程5 threejs中的材质

Three.JS教程5 threejs中的材质 一、什么是Three.js材质&#xff1f;二、Three.js的材质类型1. 材质类型2. 材质的共用属性&#xff08;1&#xff09;.alphaHash : Boolean&#xff08;2&#xff09;.alphaTest : Float&#xff08;3&#xff09;.alphaToCoverage : Boolean&am…

白酒:制曲工艺的微生物多样性及其作用

在云仓酒庄豪迈白酒的制曲工艺中&#xff0c;微生物多样性是一个关键要素。曲是白酒生产中的重要配料&#xff0c;它由小麦、麸皮等原料制成&#xff0c;经过微生物的发酵和生长而形成。微生物的多样性和相互作用对曲的品质和白酒的口感具有重要影响。 首先&#xff0c;微生物多…

【后端高频面试题--设计模式上篇】

&#x1f680; 作者 &#xff1a;“码上有前” &#x1f680; 文章简介 &#xff1a;后端高频面试题 &#x1f680; 欢迎小伙伴们 点赞&#x1f44d;、收藏⭐、留言&#x1f4ac; 往期精彩内容 【后端高频面试题–设计模式上篇】 【后端高频面试题–设计模式下篇】 【后端高频…

Git 操作以及Git 常见问题

Git 操作 git 教程&#xff1a;https://www.runoob.com/git/git-tutorial.html 基本概念 工作区&#xff1a;克隆项目到本地后&#xff0c;项目所在的文件夹&#xff1b; 暂存区&#xff1a;从工作区添加上来的变更&#xff08;新增&#xff0c;修改&#xff0c;删除&#xff…

C++面向对象程序设计-北京大学-郭炜【课程笔记(三)】

C面向对象程序设计-北京大学-郭炜【课程笔记&#xff08;三&#xff09;】 1、构造函数&#xff08;constructor&#xff09;1.1、基本概念 2、赋值构造函数2.1、基本概念2.1、复制构造函数起作用的三种情况2.2、常引用参数的使用 3、类型转换构造函数3.1、什么事类型转换构造函…

关于怎么监督机器学习训练的进度

不知道大家有没有我这种烦恼&#xff0c;运行机器学习模型的时候&#xff0c;一直在哪运行&#xff0c;也不知道啥时候会结束&#xff0c;等也不是&#xff0c;不等也不是&#xff0c;又着急想看到结果。 如下提出三种监督训练进度的方法&#xff1a; 1.使用回调函数&#xf…

Kubernetes实战:通过nodePort方式访问springboot服务

目录 一、准备工作1.1、yaml文件编写 二、创建k8s Service三、附录参考资料 一、准备工作 1.1、yaml文件编写 创建weaveservice_service.yaml文件&#xff0c;yaml文件内容如下 apiVersion: v1 kind: Service metadata:name: weaveservicenamespace: app spec:selector:app:…

寻找正确的数据衡量指标

在分析数据之前&#xff0c;需要对运营&产品设置一个目标行为。这个行为的定义应当是业务目标或者业务目标直接相关的指标&#xff0c;我们希望通过运营或者产品&#xff0c;让用户产生某种行为&#xff0c;并达到双赢的目的。 例如电商产品中&#xff0c;用户最终的行为是…

深入解析Android AIDL:实现跨进程通信的利器

深入解析Android AIDL&#xff1a;实现跨进程通信的利器 1. 介绍Android AIDL Android Interface Definition Language (AIDL) 是一种Android系统中的跨进程通信机制。AIDL允许一个应用程序的组件与另一个应用程序的组件通信&#xff0c;并在两者之间传输数据。 AIDL的主要作…

【机构vip教程】​python(1):python正则表达式匹配指定的字符开头和指定的字符结束

一&#xff0c;使用python的re.findall函数&#xff0c;匹配指定的字符开头和指定的字符结束 代码示例&#xff1a; 1 import re 2 # re.findall函数;匹配指定的字符串开头和指定的字符串结尾(前后不包含指定的字符串) 3 str01 hello word 4 str02 re.findall((?<e).*?…

[嵌入式系统-27]:RT-Thread -14- 操作系统配置:rtconfig.h文件与menuconfig命令

目录 一、rtconfig.h 1.1 概述 1.2 软硬件资源配置 1.3 功能模块选择 1.4 内核配置详解 1.5 调度器配置 1.6 硬件设备驱动配置 1.7 网络配置 1.8 调试配置 二、menuconfig 2.1 概述 2.2 主要功能 三、RT Thread配置 VS Linux配置 一、rtconfig.h 1.1 概述 rtco…