poj 2318 向量的叉积二分查找
| Time Limit: 2000MS | Memory Limit: 65536K | |
| Total Submissions: 9350 | Accepted: 4451 |
Description
John's parents came up with the following idea. They put cardboard partitions into the box. Even if John keeps throwing his toys into the box, at least toys that get thrown into different bins stay separated. The following diagram shows a top view of an example toy box.
For this problem, you are asked to determine how many toys fall into each partition as John throws them into the toy box.Input
Output
Sample Input
5 6 0 10 60 0
3 1
4 3
6 8
10 10
15 30
1 5
2 1
2 8
5 5
40 10
7 9
4 10 0 10 100 0
20 20
40 40
60 60
80 80
5 10
15 10
25 10
35 10
45 10
55 10
65 10
75 10
85 10
95 10
0
Sample Output
0: 2
1: 1
2: 1
3: 1
4: 0
5: 1 0: 2
1: 2
2: 2
3: 2
4: 2
分析:做题目比看题目容易多了,这JB英文真抽象,判断点在哪一块区域,根据向量的叉积,顺着第一个向量v看,如果w在左边,那么v和w的叉积大于0,否则小于0。
#include <iostream>
#include <cstdio>
#include <vector>
#include <string.h>
using namespace std; struct Point
{
int x,y;
Point(){}
Point(int x,int y):x(x),y(y) {}
}; typedef Point Vector;
Vector operator -(Point A,Point B){return Vector(A.x-B.x,A.y-B.y);}
int Cross(Vector A,Vector B){ return A.x*B.y-A.y*B.x;} struct Line
{
Point A,B;
}; vector<Line> v;
int num[5005]; int BinarySearch(Point P,int L,int R)
{
int mid=(L+R)>>1;
if(R-L==1) mid++;
Vector v1=v[mid].B-v[mid].A,v2=P-v[mid].A,v3;
if(Cross(v1,v2) < 0)
{
v3=v[mid-1].B-v[mid-1].A;
v2=P-v[mid-1].A;
if(Cross(v3,v2) > 0)
return mid-1;
else
return BinarySearch(P,L,mid);
}
else
return BinarySearch(P,mid,R);
} int main()
{
int i,n,m,x1,y1,x2,y2;
Line LL;
Point P;
int flag=0;
while(scanf("%d",&n),n)
{
if(flag) printf("\n");
flag=1;
v.clear();
memset(num,0,sizeof(num));
scanf("%d %d %d %d %d",&m,&x1,&y1,&x2,&y2);
LL.A.x=x1;LL.A.y=y1;LL.B.x=x1;LL.B.y=y2;
v.push_back(LL);
for(i=0;i<n;i++)
{
scanf("%d %d",&LL.A.x,&LL.B.x);
v.push_back(LL);
}
LL.A.x=x2;LL.B.x=x2;
v.push_back(LL);
for(i=0;i<m;i++)
{
scanf("%d %d",&P.x,&P.y);
num[BinarySearch(P,0,n+1)]++;
}
for(i=0;i<=n;i++) printf("%d: %d\n",i,num[i]);
}
return 0;
}
poj 2318 向量的叉积二分查找的更多相关文章
- POJ 2318 TOYS(叉积+二分)
题目传送门:POJ 2318 TOYS Description Calculate the number of toys that land in each bin of a partitioned ...
- POJ 2318 TOYS【叉积+二分】
今天开始学习计算几何,百度了两篇文章,与君共勉! 计算几何入门题推荐 计算几何基础知识 题意:有一个盒子,被n块木板分成n+1个区域,每个木板从左到右出现,并且不交叉. 有m个玩具(可以看成点)放在这 ...
- POJ 1064 Cable master(二分查找+精度)(神坑题)
POJ 1064 Cable master 一开始把 int C(double x) 里面写成了 int C(int x) ,莫名奇妙竟然过了样例,交了以后直接就wa. 后来发现又把二分查找的判断条 ...
- POJ 2318 TOYS 利用叉积判断点在线段的那一侧
题意:给定n(<=5000)条线段,把一个矩阵分成了n+1分了,有m个玩具,放在为位置是(x,y).现在要问第几个位置上有多少个玩具. 思路:叉积,线段p1p2,记玩具为p0,那么如果(p1p2 ...
- POJ 1019:Number Sequence 二分查找
Number Sequence Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 36013 Accepted: 10409 ...
- 【POJ 2318】TOYS 叉积
用叉积判断左右 快速读入写错了卡了3小时hhh #include<cmath> #include<cstdio> #include<cstring> #includ ...
- [ACM] poj 2456 Aggressive cows (二分查找)
Aggressive cows Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 5436 Accepted: 2720 D ...
- [ACM] poj 1064 Cable master (二分查找)
Cable master Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 21071 Accepted: 4542 Des ...
- POJ 3258 River Hopscotch(二分查找答案)
一个不错的二分,注释在代码里 #include <stdio.h> #include <cstring> #include <algorithm> #include ...
随机推荐
- 洛谷 P2126 Mzc家中的男家丁
题目背景 mzc与djn的…还没有众人皆知,所以我们要来宣传一下. 题目描述 mzc家很有钱(开玩笑),他家有n个男家丁,现在mzc要将她们全都聚集起来(干什么就不知道了).现在知道mzc与男家丁们互 ...
- activeandroid复制本地数据库问题总结
activeandroid no such table 解决activeandroid no such table failed to read row 0 column 1 from a curso ...
- python爬虫---实现项目(四) 用BeautifulSoup分析新浪新闻数据
这次只演示了,如何在真实项目内用到BeautifulSoup库来解析网页,而新浪的新闻是ajax加载过来的数据,在这里我们只演示解析部分数据(具体反扒机制没做分析). 代码地址:https://git ...
- Android 使用 adb命令 远程安装apk
Android 使用 adb命令 远程安装apk ./adb devices 列出所有设备 ./adb connect 192.168.1.89 连接到该设备 ./adb logcat 启动logca ...
- Lucene入门基础教程
http://www.linuxidc.com/Linux/2014-06/102856.htm
- [UVA] 704 Colour Hash
所谓"周界搜索",练习搜索的好题,双向宽搜/迭代加深均可,还有很多细节有待完善,判重有比set更优的结构,宽搜还没写,先存一下. //Writer:GhostCai &&a ...
- 【Java_多线程并发编程】基础篇—Thread类中start()和run()方法的区别
1. start() 和 run()的区别说明 start()方法: 它会启动一个新线程,并将其添加到线程池中,待其获得CPU资源时会执行run()方法,start()不能被重复调用. run()方法 ...
- bat 获取命令执行后的多个返回值,并取最后一个
最近在使用bat,遇到了这样的问题,获取adb shell cat命令之后的所有返回值,查了很长时间,才找到,现分享给大家. 举例如下: @for /f "tokens=*" %% ...
- JS(原型和原型链)
(学习自慕课网<前端JavaScript 面试技巧> JS(原型和原型链) 题目1.如何准确判断一个变量是数组类型 使用 instanceof 方法 题目2.写一个原型链继承的例子 实例: ...
- flask中的上下文_请求上下文和应用上下文
前引 在了解flask上下文管理机制之前,先来一波必知必会的知识点. 面向对象双下方法 首先,先来聊一聊面向对象中的一些特殊的双下划线方法,比如__call__.__getattr__系列.__get ...