判断两条线段的相对位置

简介: 判断两条线段的相对位置,用int[] s1表示第一条线段,int[] s2表示第二条线段,即两线段两端点的坐标为: (s1[0],s1[1]),(s1[2],s1[3])和(s2[0],s2[1]),(s2[2],s2[3])。

判断两条线段的相对位置,用int[] s1表示第一条线段,int[] s2表示第二条线段,即两线段两端点的坐标为:

(s1[0],s1[1]),(s1[2],s1[3])和(s2[0],s2[1]),(s2[2],s2[3])。如果两线段没有交点则返回"NO",只有一个交点则返回"POINT",多个交点则返回"SEGMENT"。

public class TestLine {
	/**
	 * @return 上1下-1左-1右1中0
	 */
	public static int relative(int x1, int y1, int x2, int y2, int px, int py) {
		x2 -= x1;   //把x1,y1看成原点,转换成相对原点的坐标
		y2 -= y1;
		px -= x1;
		py -= y1;
		int flag = px * y2 - py * x2;  //判断P点在线段所在直线的上方还是下方还是线段上
		if (flag == 0) {
			flag = px * x2 + py * y2; //向量相乘,x1*x2+y1*y2=|a|*|b|*cosα,正负可推出相对原点(x1,y1)的位置
			if (flag > 0) {
				px -= x2;
				py -= y2;  //转换px,py相对x2,y2的坐标,即把x2,y2看成原点
				flag = px * x2 + py * y2;  //向量相乘
				if (flag < 0) {   //点位于线段上
					flag = 0;
				}
			}
		}
		return (flag < 0) ? -1 : ((flag > 0) ? 1 : 0);
	}

	public static String testState(int[] s1, int[] s2) {
		int[] state = new int[4];
		state[0] = relative(s2[0], s2[1], s2[2], s2[3], s1[0], s1[1]);
		state[1] = relative(s2[0], s2[1], s2[2], s2[3], s1[2], s1[3]);
		state[2] = relative(s1[0], s1[1], s1[2], s1[3], s2[0], s2[1]);
		state[3] = relative(s1[0], s1[1], s1[2], s1[3], s2[2], s2[3]);

		int zeroCount = 0;
		for (int i = 0; i < state.length; i++) {
			if (state[i] == 0)
				zeroCount++;
		}
		if ((state[0] * state[1] > 0) || (state[2] * state[3] > 0)) {
			return "NO";
		} else if (zeroCount > 1) {
			if (zeroCount > 2)
				return "SEGMENT";
			int index1 = 0;
			int index2 = 0;
			if (state[0] != 0)
				index1 = 2;
			if (state[2] != 0)
				index2 = 2;
			if (s1[index1] == s2[index2] && s1[++index1] == s2[++index2]) {
				return "POINT";
			}
			return "SEGMENT";
		} else
			return "POINT";
	}

	public static void main(String[] args) {
		int[] s1 = new int[] { 0, 0, 0, 1 };
		int[] s2 = new int[] { 0, 1, 0, 2 };
		System.out.println(testState(s1, s2));
	}

}

 输出结果:POINT

目录
相关文章
|
8月前
|
算法 前端开发
判断路径是否相交
判断路径是否相交
52 0
|
3月前
|
人工智能
依次后移一个位置
依次后移一个位置。
40 12
|
5月前
|
算法
空间判断点是否在线段上
空间判断点是否在线段上
38 0
|
6月前
使其前面各数顺序向后移 m 个位置
【7月更文挑战第4天】使其前面各数顺序向后移 m 个位置。
28 1
|
8月前
假设你正在玩跳格子(所有格子排成一个纵列)游戏。需要 跳完n 个格子你才能抵达终点。 每次你可以跳 1 或 2 个格子。你有多少种不同的方法可以到达终点呢? 注意:给定 n 是一个正整数。
假设你正在玩跳格子(所有格子排成一个纵列)游戏。需要 跳完n 个格子你才能抵达终点。 每次你可以跳 1 或 2 个格子。你有多少种不同的方法可以到达终点呢? 注意:给定 n 是一个正整数。
|
8月前
|
存储 算法 Java
给定一组棋子的坐标,判断是否可以互相攻击。如果两个棋子的横纵坐标任意一个相同,则认为它们可以互相攻击。(提示:使用哈希表)
给定一组棋子的坐标,判断是否可以互相攻击。如果两个棋子的横纵坐标任意一个相同,则认为它们可以互相攻击。(提示:使用哈希表)
55 0
三角形判断
三角形判断
88 0
判断点是否在线段上
判断点是否在线段上
165 0
判断线段是否相交
判断线段是否相交
96 0
16:三角形判断
16:三角形判断
119 0