poj 2318 TOYS & poj 2398 Toy Storage (叉积)
题意:有一个矩形盒子,盒子里有一些木块线段。而且这些线段坐标是依照顺序给出的。
有n条线段,把盒子分层了n+1个区域,然后有m个玩具。这m个玩具的坐标是已知的,问最后每一个区域有多少个玩具
分析:从左往右。直到推断玩具是否在线段的逆时针方向为止。这个就须要用到叉积,当然能够用二分查找优化。
叉积:已知向量a(x1,y1),向量b(x2,y2),axb=x1*y2-x2*y1,
若axb>0,a在b的逆时针方向,若axb<0,则a在b的顺时针方向
注:每组数据后要多空一行
#include<stdio.h>
#include<string.h>
int chaji(int x1,int y1,int x2,int y2)
{
return x1*y2-x2*y1;
}
int main()
{
int u[5010],l[5010],x,y,x1,y1,x2,y2,m,n,i,j,s[5010];
while(scanf("%d",&n)!=EOF){
if(n==0)
break;
scanf("%d%d%d%d%d",&m,&x1,&y1,&x2,&y2);
for(i=0;i<n;i++)
scanf("%d%d",&u[i],&l[i]);
u[n]=l[n]=x2; //将最后一个线段加上
memset(s,0,sizeof(s));
for(i=0;i<m;i++){
scanf("%d%d",&x,&y);
for(j=0;j<=n;j++)
if(chaji(u[j]-l[j],y1-y2,x-l[j],y-y2)>0){ //叉积推断
s[j]++;
break;
}
}
for(j=0;j<=n;j++)
printf("%d: %d\n",j,s[j]);
printf("\n");
}
return 0;
}
意思与上题一样。仅仅只是给出的线段乱序的,所以须要排序,
输出也有点不同,须要输出有玩具1-m个的区间有多少个,按顺序输出
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
struct point
{
int l,u;
}p[1010];
int chaji(int x1,int y1,int x2,int y2)
{
return x1*y2-x2*y1;
}
int cmp(struct point a,struct point b)
{
if(a.l!=b.l)
return a.l<b.l;
return a.u<b.u;
}
int main()
{
int x,y,x1,y1,x2,y2,m,n,i,j,s[1010],a[1010];
while(scanf("%d",&n)!=EOF){
if(n==0)
break;
scanf("%d%d%d%d%d",&m,&x1,&y1,&x2,&y2);
for(i=0;i<n;i++)
scanf("%d%d",&p[i].u,&p[i].l);
p[n].u=p[n].l=x2;
sort(p,p+n+1,cmp); //对线段排序
memset(s,0,sizeof(s));
memset(a,0,sizeof(a));
for(i=0;i<m;i++){
scanf("%d%d",&x,&y);
for(j=0;j<=n;j++)
if(chaji(p[j].u-p[j].l,y1-y2,x-p[j].l,y-y2)>0){
s[j]++;
break;
}
}
for(j=0;j<=n;j++)
a[s[j]]++;
printf("Box\n");
for(i=1;i<=n;i++)
if(a[i])
printf("%d: %d\n",i,a[i]);
}
return 0;
}
poj 2318 TOYS & poj 2398 Toy Storage (叉积)的更多相关文章
- 【解题报告】PKU 2318 TOYS AND PKU 2398 Toy Storage
题目连接: http://poj.org/problem?id=2318 http://poj.org/problem?id=2398 两题类似的题目,2398是2318的升级版. 题目大概是 ...
- POJ 2318 TOYS(点与直线的关系 叉积&&二分)
题目链接 题意: 给定一个矩形,n个线段将矩形分成n+1个区间,m个点,问这些点的分布. 题解: 思路就是叉积加二分,利用叉积判断点与直线的距离,二分搜索区间. 代码: 最近整理了STL的一些模板,发 ...
- POJ 2318 TOYS && POJ 2398 Toy Storage(几何)
2318 TOYS 2398 Toy Storage 题意 : 给你n块板的坐标,m个玩具的具体坐标,2318中板是有序的,而2398无序需要自己排序,2318要求输出的是每个区间内的玩具数,而231 ...
- poj 2398 Toy Storage(计算几何)
题目传送门:poj 2398 Toy Storage 题目大意:一个长方形的箱子,里面有一些隔板,每一个隔板都可以纵切这个箱子.隔板将这个箱子分成了一些隔间.向其中扔一些玩具,每个玩具有一个坐标,求有 ...
- POJ 2318 TOYS(叉积+二分)
题目传送门:POJ 2318 TOYS Description Calculate the number of toys that land in each bin of a partitioned ...
- 简单几何(点与线段的位置) POJ 2318 TOYS && POJ 2398 Toy Storage
题目传送门 题意:POJ 2318 有一个长方形,用线段划分若干区域,给若干个点,问每个区域点的分布情况 分析:点和线段的位置判断可以用叉积判断.给的线段是排好序的,但是点是无序的,所以可以用二分优化 ...
- 向量的叉积 POJ 2318 TOYS & POJ 2398 Toy Storage
POJ 2318: 题目大意:给定一个盒子的左上角和右下角坐标,然后给n条线,可以将盒子分成n+1个部分,再给m个点,问每个区域内有多少各点 这个题用到关键的一步就是向量的叉积,假设一个点m在 由ab ...
- POJ 2398 - Toy Storage 点与直线位置关系
Toy Storage Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 5439 Accepted: 3234 Descr ...
- POJ 2398 Toy Storage(计算几何,叉积判断点和线段的关系)
Toy Storage Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 3146 Accepted: 1798 Descr ...
随机推荐
- eval()将json 字符串转换为数组
json ={ GW:[{id:"655",mc:"董事"},{id:"656",mc:"书记"},{id:" ...
- sql 语句的优化
sql语句的优化:在大多数情况下,为了更快的遍历表结构,优化器主要是根据定义的索引来提高性能.但是在不合理的SQL语句中,优化器会删去索引进而使用全表扫描, 一般而言,这种sql被称为劣质sql,所以 ...
- CREATE CAST - 定义一个用户定义的转换
SYNOPSIS CREATE CAST (sourcetype AS targettype) WITH FUNCTION funcname (argtype) [ AS ASSIGNMENT | A ...
- http 1.0 http 1.1 http 2.0的区别
HTTP/1.0 版的主要缺点是,每个TCP连接只能发送一个请求.发送数据完毕,连接就关闭,如果还要请求其他资源,就必须再新建一个连接. http1.1优点: 1.HTTP 1.1 版引入了持久连接( ...
- 第2节 mapreduce深入学习:15、reduce端的join算法的实现
reduce端的join算法: 例子: 商品表数据 product: pidp0001,小米5,1000,2000p0002,锤子T1,1000,3000 订单表数据 order: pid ...
- 2019浙师大校赛(浙大命题)(upc复现赛)总结
2019浙师大校赛(浙大命题)(upc复现赛)总结 早上九点开始.起得迟了,吃了早饭慌慌张张跑过去,刚到比赛就开始了. 开始分别从前往后和从后往前看题,一开始A题,第一发WA,第二次读题发现漏看了还有 ...
- PHP:图片上传
文章来源:http://www.cnblogs.com/hello-tl/p/7593033.html <?php class TL_Update_File{ private $file = n ...
- HDU 4747 Mex【线段树上二分+扫描线】
[题意概述] 一个区间的Mex为这个区间没有出现过的最小自然数,现在给你一个序列,要求求出所有区间的Mex的和. [题解] 扫描线+线段树. 我们在线段树上维护从当前左端点开始的前缀Mex,显然从左到 ...
- Spring 和 Hibernate的整合
问题 ,spring 和 hibernate 整合 如何整合 1. Spring 使用Hibernate的的SessionFactory 2. Hibernate使用Spring提供的声明式事务
- table 设置自动宽度后 td 的固定宽度 在 谷歌浏览器自动拉伸
table 设置自动宽度后 td 的固定宽度 在 谷歌浏览器自动拉伸 解决方案 <table style="table-layout:fixed;">