`
scott________
  • 浏览: 21761 次
  • 性别: Icon_minigender_1
  • 来自: 哈尔滨
最近访客 更多访客>>
社区版块
存档分类
最新评论

poj 2318 TOYS 点 直线 位置关系

阅读更多
题目描述:http://poj.org/problem?id=2318
判断点与直线位置关系的题

#include <cstdio>
#include <algorithm>
using namespace std;

struct point {
	int x,y;
};

struct line {
	point a,b;
};

int xmult(line seg, point p) {
	return (seg.b.x - p.x) * (seg.a.y - p.y) - (seg.a.x - p.x) * (seg.b.y - p.y);
}

bool comp(point p1, point p2) {
	if(p1.x != p2.x)
		return p1.x < p2.x;
	return p1.y < p2.y;
}

int main() {
	//freopen("in.txt", "r", stdin);
	int n, m;
	point lu, rl;
	point toys[5005];
	line segs[5005];
	int cnt[5005];
	while(scanf("%d", &n) != EOF) {
		if(n == 0)
			break;
		for(int i = 0; i < n  + 1; i++)
			cnt[i] = 0;
		scanf("%d %d %d %d %d", &m, &lu.x, &lu.y, &rl.x, &rl.y);
		segs[0].a = lu;
		segs[0].b.x = lu.x;
		segs[0].b.y = rl.y;
		segs[n + 1].a.x = rl.x;
		segs[n + 1].a.y = lu.y;
		segs[n + 1].b = rl;
		
		int u, l;
		for(int i = 1; i <= n; i++) {
			scanf("%d %d", &u, &l);
			segs[i].a.x = u;
			segs[i].a.y = lu.y;
			segs[i].b.x = l;
			segs[i].b.y = rl.y;
		}
		for(int i = 0; i < m; i++)
			scanf("%d %d", &toys[i].x, &toys[i].y);
			
		int k = 0;
        sort(toys, toys + m, comp);
		for(int i = 0; i < m; i++) {
			for(int j = 0; j <= n; j++) {   //避免重新从j = 0 开始搜索
				if(xmult(segs[j], toys[i]) <= 0
					&& xmult(segs[j + 1], toys[i]) >= 0) {
					cnt[j]++;
                    k = j;  //避免重新从j = 0 开始搜索
					break;
				}
			}
		}
		for(int i = 0; i <= n; i++)
			printf("%d: %d\n", i, cnt[i]);
		
		printf("\n");
		
	}
	return 0;
}





分享到:
评论

相关推荐

    poj 2653代码 判断两直线是否相交

    题目"POJ 2653"是一个典型的计算几何问题,它的目标是编写程序来检查给定的一组直线(棍子)中哪些是相交的。 首先,我们需要了解计算几何中的基本数据结构和方法。在提供的代码中,`PointStruct`定义了表示二维...

    POj最接近点对问题

    POJ 最接近点对问题 ACM北大 using namespace std; struct Point { float x; float y; };

    POJ.rar_poj java_poj1048

    【标题】"POJ.rar_poj java_poj1048" 涉及的知识点主要围绕编程竞赛中的“约瑟夫环”问题,这里是一个加强版,使用Java语言进行解决。 【描述】"POJ1048,加强版的约瑟夫问题 难度中等" 提示我们,这个问题是编程...

    poj题目分类

    * 递推关系:例如 poj3252、poj1850、poj1019、poj1942。 2. 数论: * 素数与整除问题。 * 进制位。 * 同余模运算:例如 poj2635、poj3292、poj1845、poj2115。 3. 计算方法: * 二分法求解单调函数相关知识...

    POJ算法题目分类

    * 叉积和点积的运用:叉积和点积的运用是指解决问题的叉积和点积的运用算法,如 poj2031、poj1039。 * 多边型的简单算法和相关判定:多边型的简单算法和相关判定是指解决问题的多边型的简单算法和相关判定算法,如 ...

    POJ2002-Squares

    【标题】"POJ2002-Squares"是一个经典的计算机编程题目,源自北京大学的在线判题系统(POJ,即PKU Online Judge)。这个题目主要涉及到算法设计和实现,尤其是数学和动态规划方面的知识。 【描述】"解题报告+AC代码...

    ACM-POJ 算法训练指南

    2. **线段交**:计算线段是否相交及交点位置(poj3176, poj1080, poj1159)。 ### 七、概率统计 1. **概率计算**:计算随机事件的概率(POJ3252, poj1850, poj1019, poj1942)。 2. **期望值**:计算期望值问题...

    poj训练计划.doc

    - 最短路径算法:如Dijkstra算法和Bellman-Ford算法,用于找到两点间的最短路径,如`poj1062, poj2253`。 - 最小生成树算法:如Prim算法和Kruskal算法,用于找出图中的最小生成树,如`poj1789, poj2485`。 - 拓扑...

    poj各种分类

    适用于有向无环图,帮助分析任务依赖关系,如poj1094所示。 #### 匹配算法 包括二分图的最大匹配和KM算法,用于解决资源分配类问题,如poj3041和poj3020。 ### 三、数据结构 #### 字符串处理 如Trie树(前缀树)...

    POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类

    根据提供的信息,我们可以总结出以下相关的IT知识点,主要聚焦于编程竞赛中的算法和技术: ### POJ分类概述 ...以上提到的知识点仅为部分分类,POJ平台还包含了更多类型的题目,供有兴趣的人士进一步探索和学习。

    POJ1159-Palindrome

    【标题】"POJ1159-Palindrome" 是北京大学在线编程平台POJ上的一道编程题目。这道题目主要考察的是字符串处理和回文判断的知识点。 【描述】"北大POJ1159-Palindrome 解题报告+AC代码" 暗示了解决这道问题的方法和...

    jihe.rar_2289_POJ 3714_poj3714_poj3714 Ra_visual c

    标题中的"jihe.rar_2289_POJ 3714_poj3714_poj3714 Ra_visual c" 提到了一个压缩文件,可能包含有关编程竞赛或算法解决的资源,特别是与POJ(Problem On Judge)平台上的问题3714相关的。"Ra_visual c"可能指的是...

    poj 3414解题报告

    poj 3414解题报告poj 3414解题报告poj 3414解题报告poj 3414解题报告

    POJ1201-Intervals

    【标题】"POJ1201-Intervals" 是北京大学在线编程平台POJ上的一道题目,这道题目主要涉及计算机科学中的算法设计与分析,尤其是数据结构和时间复杂度优化方面的知识。 【描述】"北大POJ1201-Intervals 解题报告+AC...

    poj 1012解题报告

    poj 1012解题报告poj 1012解题报告poj 1012解题报告poj 1012解题报告

    POJ入门题库(含解题思路和答案)

    23. POJ——2722 学分绩点:可能需要处理学分和成绩数据,计算GPA(Grade Point Average),涉及到数据处理和计算规则。 24. POJ——2733 判断闰年:涉及到日期处理和基础的数学知识,判断一个年份是否为闰年。 ...

    poj 2329解题报告

    poj 2329解题报告poj 2329解题报告poj 2329解题报告poj 2329解题报告

    poj 1659解题报告

    poj 1659解题报告poj 1659解题报告poj 1659解题报告poj 1659解题报告

    POJ1011-Sticks

    题目要求参赛者编写程序,输入是线段的数量N和每个线段的起始点和结束点坐标,输出是使线段分离所需的最小移除数量。 【解题思路】解题的关键在于理解线段之间的关系,以及如何有效地进行分组。这通常涉及到图论中...

    POJ1837-Balance

    【标题】"POJ1837-Balance"是一个在线编程竞赛题目,源自著名的编程练习平台POJ(Programming Online Judge)。这个题目旨在测试参赛者的算法设计和实现能力,特别是处理平衡问题的技巧。 【描述】"解题报告+AC代码...

Global site tag (gtag.js) - Google Analytics