poj3819 Coverage (求直线与圆的交占直线的百分比 )

poj3819 Coverage (求直线与圆的交占直线的百分比 )

大家好,又见面了,我是全栈君。

    题意:给你一条直线和若干个圆,求圆与直线相交的长度占整条直线的比例

   解题思路:通过定比分点的方法求出圆与直线的交占圆的比例。

    第一步:(确定投影的方向是x轴还是y轴) 

   (1)当直线的line.s(x, y), line.e(x, y)的line.s.x与line.e.x不同一时候,这条直线能够等同于起点为line.s.x, line.e.x;

   (2)不满足(1)时(即line.s.x==line.e.x时),当直线的line.s(x, y), line.e(x, y)的line.s.y与line.e.y不同一时候。这条直线能够等同于起点为line.s.x, line.e.x;

   (3)当不满足(1)以及(2)时(即line.s==line.e),这时候直线为一个点,不论什么的圆都与它没有交。圆占整条直线的比例为0;

    第二步:(将圆投影到第一步得到的直线上)

    求出圆在直线上的投影的范围;

    第三步:

    求出全部圆的并。将圆的并除以线段的长度。求圆与线段的交占线段的百分比;


   

#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstdlib>
#include <cmath>
using namespace  std;
const int MAX = 300;
struct Node
{
	double x, y;
};
struct Line
{
	Node s, e;
};
Line line;
Node p[MAX];
double A, B, C, delta;
double x, y, r;
double x11, y11, dx, dy;
Node tmp, cir;
double sqr(double x)
{
	return x * x;
}
int circle_cross_line(Node s, Node e, Node O, double r)//推断圆与直线是否有交点
{
	double x0 = O.x, y0=O.y;
	x11 = s.x, y11 = s.y;
	double x2 = e.x, y2 = e.y;
	dx = x2 - x11, dy = y2 - y11;
	A = dx * dx + dy*dy;
	B = 2 * dx * (x11 - x0) + 2 * dy * (y11 - y0);
	C = sqr(x11-x0) + sqr(y11-y0) - sqr(r);
	delta = sqr(B) - 4 * A * C;
	return delta > 0;
}
int cmp(Node a, Node b)
{
	if (a.x < b.x)
		return 1;
	return 0;
}
int main()
{
	int n, i, cnt;
	int flag, flagnum;
	double leng;
	while (scanf("%d", &n) && n)
	{
		flagnum = 0;
		scanf("%lf%lf%lf%lf", &line.s.x, &line.s.y, &line.e.x, &line.e.y);
		if (line.s.x!=line.e.x)
		{
			if (line.s.x < line.e.x)
			{
				tmp.x = line.s.x;
				tmp.y = line.e.x;
			}
			else
			{
				tmp.x = line.e.x;
				tmp.y = line.s.x;
			}
			flag = 0;
			leng = fabs(line.e.x - line.s.x);
		}
		else if (line.s.x==line.e.x && line.s.y!=line.e.y)
		{
			if (line.s.y < line.e.y)
			{
				tmp.x = line.s.y;
				tmp.y = line.e.y;
			}
			else
			{
				tmp.x = line.e.y;
				tmp.y = line.s.y;
			}
			flag = 1;
			leng = fabs(line.e.y - line.s.y);
		}
		else
			flagnum = 1;
		cnt = 0;
		for (i=0; i<n; i++)
		{
			scanf("%lf%lf%lf", &cir.x, &cir.y, &r);
			if (flagnum)
				continue;
			if (circle_cross_line(line.s, line.e, cir, r))
			{
				p[cnt].x = (-B-sqrt(delta))/(2.0*A);
				p[cnt].y = (-B+sqrt(delta))/(2.0*A);
				if (flag==0)
				{
					p[cnt].x = p[cnt].x * dx + x11;
					p[cnt].y = p[cnt].y * dx + x11;
				}
				else
				{
					p[cnt].x = p[cnt].x * dy + y11;
					p[cnt].y = p[cnt].y * dy + y11;
				}
				if (p[cnt].x>p[cnt].y)
				{
					double t = p[cnt].x;
					p[cnt].x = p[cnt].y;
					p[cnt].y = t;
				}
				if (p[cnt].x>tmp.y || p[cnt].y<tmp.x)
					continue;
				if (p[cnt].x<tmp.x)
					p[cnt].x = tmp.x;
				if (p[cnt].y>tmp.y)
					p[cnt].y = tmp.y; 
				cnt++;
			}
		}
		if (flagnum || cnt==0)
			printf("0.00\n");
		else
		{
			sort(p, p+cnt, cmp);
			double sum = 0;
			tmp = p[0];
			for (i=1; i<cnt; i++)
			{
				if (p[i].x < tmp.y)
				{
					if (p[i].y > tmp.y)
						tmp.y = p[i].y;
				}
				else
				{
					sum += tmp.y - tmp.x;
					tmp = p[i];
				}
			}
			sum += tmp.y - tmp.x;
			printf("%.2f\n", sum/leng*100.0);
		}
	}
	return 0;
}

  


版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/116138.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Java 注解(Annotation)

    Java 注解(Annotation)文章目录Annotation工作方式JDK5内建Annotation限定Override父类方法@Override标示方法为Deprecated@Deprectated抑制编译程序警告@SuppressWarnings自定义Annotation类型Annotation高级特性Annotation工作方式从Java5.0版发布以来,5.0平台提供了一个正式的annoatation功能:允许开…

    2022年7月7日
    17
  • Wireshark数据抓包分析之FTP协议

    Wireshark数据抓包分析之FTP协议实验步骤一  配置FTP服务器,并在测试者机器上登录FTP服务器在局域网环境中,我们使用一个小工具来(QuickEasyFTPServer)实现FTP服务器。配置QuickEasyFTPServer 软件双击桌面的QuickEasyFTPServer,如下图如上图,可以创建匿名的,但是匿名就没有密码,这里我们创建一个,下一步输入密码,这里随意,记住即可,后面客户端登录会用到。下一…

    2022年6月22日
    132
  • Spring进阶之路(1)-Spring核心机制:依赖注入/控制反转

    Spring进阶之路(1)-Spring核心机制:依赖注入/控制反转

    2021年9月13日
    45
  • 猿创征文|点亮JAVA技术之灯(线程篇)「建议收藏」

    猿创征文|点亮JAVA技术之灯(线程篇)「建议收藏」线程安全就是说多线程访问同一段代码,不会产生不确定的结果。又是一个理论的问题,各式各样的答案有很多,我给出一个个人认为解释地最好的:如果你的代码在多线程下执行和在单线程下执行永远都能获得一样的结果,那么你的代码就是线程安全的。(1)不可变像String、Integer、Long这些,都是final类型的类,任何一个线程都改变不了它们的值,要改变除非新创建一个,因此这些不可变对象不需要任何同步手段就可以直接在多线程环境下使用(2)绝对线程安全不管运行时环境如何,调用者都不需要额外的同步措施。……….

    2025年8月23日
    9
  • python中数组(numpy.array)的基本操作「建议收藏」

    python中数组(numpy.array)的基本操作「建议收藏」 为什么要用numpy   Python中提供了list容器,可以当作数组使用。但列表中的元素可以是任何对象,因此列表中保存的是对象的指针,这样一来,为了保存一个简单的列表[1,2,3]。就需要三个指针和三个整数对象。对于数值运算来说,这种结构显然不够高效。   Python虽然也提供了array模块,但其只支持一维数组,不支持多维数组(在TensorFlow里面偏向于矩阵理解),也…

    2022年8月13日
    18
  • rpcbind

    rpcbind一、介绍通俗的来说,rpcbind是NFS中用来进行消息通知的服务。一般情况下rpcbind运行在111端口。并且NFS配置开启rpcbind_enable="YES"

    2022年7月3日
    37

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号