poj 2398 Toy Storage 【计算几何】【点和线的关系】

2024-05-15 14:32

本文主要是介绍poj 2398 Toy Storage 【计算几何】【点和线的关系】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目链接:http://poj.org/problem?id=2398

题目大意:这次的题目和前一道题目几乎是一样的,不同之处在于这次给出的线不是有顺序的,还有就是输出的时候有一个优化。

基本的分析见我上篇博客:http://blog.csdn.net/u010468553/article/details/39474007

注意sort函数中cmp的编写还有后期数据的整理

#include<iostream>
#include<stdio.h>
#include<cstring>
#include<stdlib.h>
#include<algorithm>
using namespace std;
struct point {double x;double y;point(const double &x = 0, const double &y = 0):x(x), y(y){} //注意最后两个字母别打错了void in(){scanf("%lf%lf",&x,&y);}void out()const{ printf("%.2lf %.2lf\n",x,y);}
}s,e;struct line{point s;point e;
};int n,m; //n条线(分成n+1个区域) m个玩具 最后输出每个区域内的玩具个数
line L[5005];
point P;
int cnt[5005];//计算叉乘(P1-P0)X(P2-P0)
double xmult(point p1,point p2,point p0){return (p1.x-p0.x)*(p2.y-p0.y) - (p1.y-p0.y)*(p2.x-p0.x);
}bool cmp(const line& l1, const line& l2) {if (min(l1.s.x, l1.e.x) == min(l2.s.x, l1.e.x))return max(l1.s.x, l1.e.x) < max(l2.s.x, l1.e.x);return min(l1.s.x, l1.e.x) < min(l2.s.x, l1.e.x);
}void B_search(point P){int l=0,r=n-1,mid;while(l<r){mid = (l+r)/2;if(xmult(P,L[mid].s,L[mid].e) > 0) l = mid + 1;else r = mid;
}if(xmult(P,L[l].s,L[l].e)<0) cnt[l]++;else cnt[l+1]++;
}int main ()
{while(~scanf("%d",&n)){memset(cnt,0,sizeof(cnt));if(n==0) break;scanf("%d %lf %lf %lf %lf",&m,&s.x,&s.y,&e.x,&e.y);for(int i=0;i<n;i++){double t1,t2;scanf("%lf %lf",&t1,&t2);L[i].s.x=t1;L[i].s.y=s.y;L[i].e.x=t2;L[i].e.y=e.y;}sort(L, L+n, cmp);for(int i=0;i<m;i++){scanf("%lf %lf",&P.x,&P.y);B_search(P);}int ans[5005];memset(ans,0,sizeof(ans));for(int i=0;i<=n;i++) ans[ cnt[i] ] ++ ;printf ("Box\n");for (int i = 1; i <= m; i++)if (ans[i] != 0) {printf ("%d: %d\n", i, ans[i]);m -= i * cnt[i];}}
}


这篇关于poj 2398 Toy Storage 【计算几何】【点和线的关系】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/992075

相关文章

Python并行处理实战之如何使用ProcessPoolExecutor加速计算

《Python并行处理实战之如何使用ProcessPoolExecutor加速计算》Python提供了多种并行处理的方式,其中concurrent.futures模块的ProcessPoolExecu... 目录简介完整代码示例代码解释1. 导入必要的模块2. 定义处理函数3. 主函数4. 生成数字列表5.

Java计算经纬度距离的示例代码

《Java计算经纬度距离的示例代码》在Java中计算两个经纬度之间的距离,可以使用多种方法(代码示例均返回米为单位),文中整理了常用的5种方法,感兴趣的小伙伴可以了解一下... 目录1. Haversine公式(中等精度,推荐通用场景)2. 球面余弦定理(简单但精度较低)3. Vincenty公式(高精度,

windows和Linux使用命令行计算文件的MD5值

《windows和Linux使用命令行计算文件的MD5值》在Windows和Linux系统中,您可以使用命令行(终端或命令提示符)来计算文件的MD5值,文章介绍了在Windows和Linux/macO... 目录在Windows上:在linux或MACOS上:总结在Windows上:可以使用certuti

Tomcat版本与Java版本的关系及说明

《Tomcat版本与Java版本的关系及说明》:本文主要介绍Tomcat版本与Java版本的关系及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Tomcat版本与Java版本的关系Tomcat历史版本对应的Java版本Tomcat支持哪些版本的pythonJ

python安装whl包并解决依赖关系的实现

《python安装whl包并解决依赖关系的实现》本文主要介绍了python安装whl包并解决依赖关系的实现,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录一、什么是whl文件?二、我们为什么需要使用whl文件来安装python库?三、我们应该去哪儿下

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

MYSQL关联关系查询方式

《MYSQL关联关系查询方式》文章详细介绍了MySQL中如何使用内连接和左外连接进行表的关联查询,并展示了如何选择列和使用别名,文章还提供了一些关于查询优化的建议,并鼓励读者参考和支持脚本之家... 目录mysql关联关系查询关联关系查询这个查询做了以下几件事MySQL自关联查询总结MYSQL关联关系查询

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

如何用Java结合经纬度位置计算目标点的日出日落时间详解

《如何用Java结合经纬度位置计算目标点的日出日落时间详解》这篇文章主详细讲解了如何基于目标点的经纬度计算日出日落时间,提供了在线API和Java库两种计算方法,并通过实际案例展示了其应用,需要的朋友... 目录前言一、应用示例1、天安门升旗时间2、湖南省日出日落信息二、Java日出日落计算1、在线API2

poj 3974 and hdu 3068 最长回文串的O(n)解法(Manacher算法)

求一段字符串中的最长回文串。 因为数据量比较大,用原来的O(n^2)会爆。 小白上的O(n^2)解法代码:TLE啦~ #include<stdio.h>#include<string.h>const int Maxn = 1000000;char s[Maxn];int main(){char e[] = {"END"};while(scanf("%s", s) != EO