POJ 2318--TOYS(二分找点,叉积判断方向)
| Time Limit: 2000MS | Memory Limit: 65536K | |
| Total Submissions: 17974 | Accepted: 8539 | 
Description
Mom and dad have a problem - their child John never puts his toys away when he is finished playing with them. They gave John a rectangular box to put his toys in, but John is rebellious and obeys his parents by simply throwing his toys into the box. All the toys get mixed up, and it is impossible for John to find his favorite toys.
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
Hint
Source
- 题意:给n条边,划分成n+1个区域,再给定m个点坐标,点不会落在边界上和区域外,问每个区域中各自存在多少个点
- 代码如下  
#include<iostream> 
 #include<cstring>
 #include<string>
 #include<algorithm>
 #include<vector>
 #include<stack>
 #include<bitset>
 #include<cstdio>
 #include<cstdlib>
 #include<cmath>
 #include<set>
 #include<list>
 #include<deque>
 #include<map>
 #include<queue>
 using namespace std;
 const int MAX = ; typedef struct point {
 int x;
 int y;
 }point;
 typedef struct value {
 point start;
 point end;
 }v;
 v edge[MAX];
 int sum[MAX];
 int n, m, x1, y11, x2, y2, flag = ;
 point tp;
 int Xj, Yj;
 int multi(point p1, point p2, point p0) { //判断p1p0和p2p0的关系,<0,p1p0在p2p0的逆时针方向
 return (p1.x - p0.x)*(p2.y - p0.y) - (p2.x - p0.x)*(p1.y - p0.y);
 }
 void inset(point p) {
 int low = , high = n;
 while (low <= high) {
 int mid = (high + low) / ;
 if (multi(p, edge[mid].start, edge[mid].end) < ) /*点p1在边的左侧*/
 high = mid - ;
 else //点p在边的右侧
 low = mid + ;
 }
 if (multi(p, edge[low-].start, edge[low-].end) < )
 sum[low-]++;
 else
 sum[low]++;
 }
 int main() {
 while (~scanf("%d", &n) && n) {
 memset(sum, , sizeof(sum));
 if (flag == )flag++;
 else printf("\n");
 scanf("%d%d%d%d%d", &m, &x1, &y11, &x2, &y2);
 int Ui, Li;
 for (int i = ; i < n; i++) {
 scanf("%d%d", &Ui, &Li);
 edge[i].start.x = Ui;
 edge[i].start.y = y11;
 edge[i].end.x = Li;
 edge[i].end.y = y2;
 }
 edge[n].start.x = x2;
 edge[n].start.y = y11;
 edge[n].end.x = x2;
 edge[n].end.y = y2;
 for (int j = ; j < m; j++) {
 scanf("%d%d", &Xj, &Yj);
 tp.x = Xj;
 tp.y = Yj;
 inset(tp);
 }
 for (int i = ; i <= n; i++)
 printf("%d: %d\n", i, sum[i]);
 }
 return ;
 }
- Experience: 前面点的构造写成 - edge[i].start = { Ui,y11 };
 edge[i].end = { Li,y2 };- 当发现这个错误的时候,我自己都被自己蠢哭了,Wa了2页,一直以为是叉积方向搞错了,原来不是ORZ 
- 这个是我真正意义上第一道计算几何,mark一下。
POJ 2318--TOYS(二分找点,叉积判断方向)的更多相关文章
- POJ 2318 TOYS (计算几何,叉积判断)
		TOYS Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 8661 Accepted: 4114 Description ... 
- poj 2318 TOYS (二分+叉积)
		http://poj.org/problem?id=2318 TOYS Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 101 ... 
- POJ 2318 TOYS | 二分+判断点在多边形内
		题意: 给一个矩形的区域(左上角为(x1,y1) 右下角为(x2,y2)),给出n对(u,v)表示(u,y1) 和 (v,y2)构成线段将矩形切割 这样构成了n+1个多边形,再给出m个点,问每个多边形 ... 
- 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个点,问这些点的分布. 题解: 思路就是叉积加二分,利用叉积判断点与直线的距离,二分搜索区间. 代码: 最近整理了STL的一些模板,发 ... 
- POJ 2318 TOYS (叉积+二分)
		题目: Description Calculate the number of toys that land in each bin of a partitioned toy box. Mom and ... 
- POJ 2318 TOYS【叉积+二分】
		今天开始学习计算几何,百度了两篇文章,与君共勉! 计算几何入门题推荐 计算几何基础知识 题意:有一个盒子,被n块木板分成n+1个区域,每个木板从左到右出现,并且不交叉. 有m个玩具(可以看成点)放在这 ... 
- POJ 2318  TOYS 利用叉积判断点在线段的那一侧
		题意:给定n(<=5000)条线段,把一个矩阵分成了n+1分了,有m个玩具,放在为位置是(x,y).现在要问第几个位置上有多少个玩具. 思路:叉积,线段p1p2,记玩具为p0,那么如果(p1p2 ... 
- 向量的叉积 POJ 2318 TOYS & POJ 2398 Toy Storage
		POJ 2318: 题目大意:给定一个盒子的左上角和右下角坐标,然后给n条线,可以将盒子分成n+1个部分,再给m个点,问每个区域内有多少各点 这个题用到关键的一步就是向量的叉积,假设一个点m在 由ab ... 
- 2018.07.03 POJ 2318 TOYS(二分+简单计算几何)
		TOYS Time Limit: 2000MS Memory Limit: 65536K Description Calculate the number of toys that land in e ... 
随机推荐
- DJango小总结一
			views.py def func(request): # 包含所有的请求数据 ... ... 
- hdu 3265 矩形剪块面积并
			http://acm.hust.edu.cn/vjudge/problem/10769 给n张海报,在每张海报上剪掉一个矩形,求面积并 把剪块的海报分成四个矩形,就是普通的求面积并问题了 #inclu ... 
- ZROJ#397. 【18提高7】模仿游戏(爆搜)
			题意 题目链接 Sol 考试的时候调了1.5h没调出来我真是菜爆了... 读完题目后不难发现,每次约束的条件相当于是\(b[((x[i] + i) % N + (i / N) % N) % N] = ... 
- Linux服务器性能评估与优化(二)
			网络内容总结(感谢原创) 1.Linux内核参数优化 内核参数是用户和系统内核之间交互的一个接口,通过这个接口,用户可以在系统运行的同时动态更新内核配置,而这些内核参数是通过Linux Proc文件系 ... 
- sheepdog
- hibernate_ID生成策略
			increment:主键按数值顺序递增.此方式的实现机制为在当前应用实例中维持一个变量,以保存着当前的最大值,之后每次需要生成主键的时候将此值加1作为主键.这种方式可能产生的问题是:如果当前有多个实例 ... 
- 【Leetcode】【Easy】Binary Tree Level Order Traversal II
			Given a binary tree, return the bottom-up level order traversal of its nodes' values. (ie, from left ... 
- 记录一次 sql在数据库可以查到 mybatis代码查不到的问题
			原始代码: 查不到 SELECT b.ID, b.PRICE_ITEM_CODE, b.PRICE_NAME, b.DES_SITE_CODE, b.SRC_SITE_CODE, b.CALC_TYP ... 
- ZT在谷歌上班感受如何?
			在谷歌上班感受如何? 2013-11-05 作者:腾讯科技 出处: 互联网 责编:zlu 在谷歌这家全球最大最有抱负的技术公司工作将是怎样的情景呢?是天堂般的享受,还是地狱般的折磨呢?下面看一 ... 
- Markdown 学习
			一级标题 一级标题 === 或 # 一级标题 二级标题 二级标题 --- 或 ## 二级标题 三级标题 ### 三级标题 链接Gayhub [Gayhub](https://www.github.co ... 
