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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • IDataParameter调用存储过程

    IDataParameter调用存储过程

    2021年12月6日
    53
  • Android gif 录屏[通俗易懂]

    Android gif 录屏[通俗易懂]/***********************************************************************************Androidgif录屏*说明:*有时候需要用到Android录制动态屏幕信息,转成gif方便存放。**…

    2022年9月19日
    3
  • from_unixtime函数类型_localtime_r函数

    from_unixtime函数类型_localtime_r函数Unix时间戳(Unixtimestamp),是一种时间表示方式,定义为从格林威治时间1970年01月01日00时00分00秒起至现在的总秒数。在MySQL中如何格式化时间戳?在mysql中因为

    2022年8月2日
    6
  • ViewPager 2 使用讲解「建议收藏」

    ViewPager 2 使用讲解「建议收藏」之前早有耳闻Google为我们提供新的控件来替换老旧的ViewPager进而解决一些不好解决的bug问题,巴拉巴拉一大堆,就是前因后果啥的…相信读者已经在“张鸿洋”大神、“郭霖”大神或者是其他Android大佬的公众号那里看见了许许多多了,或许各位感觉很无聊了,笔者菜鸟,分析不了历史背景,也不是很懂源码,但是小菜鸟,可以带给位看官尝个鲜,教你怎么用,怎么上手哈,闲话不多说,我们步入正题。…

    2022年7月22日
    11
  • 2021年最好用&完全免费的图片压缩网站、软件推荐(包括GIF)

    2021年最好用&完全免费的图片压缩网站、软件推荐(包括GIF)最近我有遇到一个很奇怪的问题因为我不是转用AppleMusic本地化听歌了????所以很多歌的歌曲信息都是我自己补充的,当然也包括封面但我在用iTunes把歌传到iPhone上来听的时候,有首歌的封面怎么都同步不过来我来回同步了几遍,还重新连接了几次,甚至换回了有线来同步,这个封面始终都还是同步不上…我就一直奇了怪了直到我想重新编辑一下封面,重新添加,我才发现…好家伙,一张封面竟然有18M!?比我MP3本身都要大了,难怪我添加不上呢完全被它小小的外表给欺骗了我后来把图片

    2022年6月18日
    24
  • 【转】Asp.NetMve移除HTTP Header中服務器信息Server、X-AspNet-Version、X-AspNetMvc-Version、X-Powered-By:ASP.NET…

    【转】Asp.NetMve移除HTTP Header中服務器信息Server、X-AspNet-Version、X-AspNetMvc-Version、X-Powered-By:ASP.NET…默認情況下Chrome中截獲的HTTPHeader信息:Cache-Control:private,s-maxage=0Content-Encoding:gzipContent-Length:1184Content-Type:text/html;charset=utf-8Date:Sun,08Oct201705:01:37GMTServer:Micros…

    2022年9月29日
    2

发表回复

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

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