链接:poj 2318

题意:有一个矩形盒子,盒子里有一些木块线段。而且这些线段坐标是依照顺序给出的。

有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;
}

id=2398">链接:poj 2398

意思与上题一样。仅仅只是给出的线段乱序的,所以须要排序,

输出也有点不同,须要输出有玩具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 &amp; poj 2398 Toy Storage (叉积)的更多相关文章

  1. 【解题报告】PKU 2318 TOYS AND PKU 2398 Toy Storage

    题目连接: http://poj.org/problem?id=2318     http://poj.org/problem?id=2398 两题类似的题目,2398是2318的升级版. 题目大概是 ...

  2. POJ 2318 TOYS(点与直线的关系 叉积&&二分)

    题目链接 题意: 给定一个矩形,n个线段将矩形分成n+1个区间,m个点,问这些点的分布. 题解: 思路就是叉积加二分,利用叉积判断点与直线的距离,二分搜索区间. 代码: 最近整理了STL的一些模板,发 ...

  3. POJ 2318 TOYS && POJ 2398 Toy Storage(几何)

    2318 TOYS 2398 Toy Storage 题意 : 给你n块板的坐标,m个玩具的具体坐标,2318中板是有序的,而2398无序需要自己排序,2318要求输出的是每个区间内的玩具数,而231 ...

  4. poj 2398 Toy Storage(计算几何)

    题目传送门:poj 2398 Toy Storage 题目大意:一个长方形的箱子,里面有一些隔板,每一个隔板都可以纵切这个箱子.隔板将这个箱子分成了一些隔间.向其中扔一些玩具,每个玩具有一个坐标,求有 ...

  5. POJ 2318 TOYS(叉积+二分)

    题目传送门:POJ 2318 TOYS Description Calculate the number of toys that land in each bin of a partitioned ...

  6. 简单几何(点与线段的位置) POJ 2318 TOYS && POJ 2398 Toy Storage

    题目传送门 题意:POJ 2318 有一个长方形,用线段划分若干区域,给若干个点,问每个区域点的分布情况 分析:点和线段的位置判断可以用叉积判断.给的线段是排好序的,但是点是无序的,所以可以用二分优化 ...

  7. 向量的叉积 POJ 2318 TOYS & POJ 2398 Toy Storage

    POJ 2318: 题目大意:给定一个盒子的左上角和右下角坐标,然后给n条线,可以将盒子分成n+1个部分,再给m个点,问每个区域内有多少各点 这个题用到关键的一步就是向量的叉积,假设一个点m在 由ab ...

  8. POJ 2398 - Toy Storage 点与直线位置关系

    Toy Storage Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 5439   Accepted: 3234 Descr ...

  9. POJ 2398 Toy Storage(计算几何,叉积判断点和线段的关系)

    Toy Storage Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 3146   Accepted: 1798 Descr ...

随机推荐

  1. SQL 触发器-如何查看当前数据库中有哪些触发器

    在查询分析器中运行: use 数据库名goselect * from sysobjects where xtype='TR' sysobjects 保存着数据库的对象,其中 xtype 为 TR 的记 ...

  2. Node.js——环境变量

  3. Node.js——body方式提交数据

    引入核心模块 http,利用其 api(http.createServer) 返回一个 http.server 实例,这个实例是继承于net.Server,net.Server 也是通过net.cre ...

  4. leetcode_378. Kth Smallest Element in a Sorted Matrix_堆的应用

    Given a n x n matrix where each of the rows and columns are sorted in ascending order, find the kth ...

  5. vue-router 基本使用(vue工程化)

    (1)概念: 路由,其实就是指向的意思,当我点击页面上的home按钮时,页面中就要显示home的内容,如果点击页面上的about 按钮,页面中就要显示about 的内容.Home按钮  => h ...

  6. 0.ssm web项目中的遇到的坑

    1.自定义的菜单,href为项目的相对路径,即: : 点击一个菜单,后再点击另一个菜单,然后发现浏览器地址栏的链接是在上一个链接后面拼接的,也就报错了. 解决办法: 每一个菜单的href前增加&quo ...

  7. zabbix4.2学习笔记--zabbix安装

    环境 系统信息 发行版 版本 ip 关系 主机名 centos 7.5 192.168.181.135 服务端 server centos 7.5 192.168.181.136 客户端 client ...

  8. 三个层面学playbook(核心)

    三个层面学playbook(核心) ansible-playbook是ansible工具中的核心,对比ad-hoc(ansible)命令,可以把playbook理解为一系列动作的组成,结果传递.判断等 ...

  9. dbeaver能执行存储过程,db2命令编辑器里面不行

  10. Linux命令学习(6):paste合并几列文件

    如果我们有三个文件: $ cat name.txt #姓名文档 Kevin Mary Tom $ cat gender.txt #性别文档 M F M $ cat age.txt #年龄文档 我们想把 ...