给出圆的圆心和半径,以及三角形的三个顶点,问圆同三角形是否相交。相交输出"Yes",否则输出"No"。(三角形的面积大于0)。

 
Input
第1行:一个数T,表示输入的测试数量(1 <= T <= 10000),之后每4行用来描述一组测试数据。
4-1:三个数,前两个数为圆心的坐标xc, yc,第3个数为圆的半径R。(-3000 <= xc, yc <= 3000, 1 <= R <= 3000)
4-2:2个数,三角形第1个点的坐标。
4-3:2个数,三角形第2个点的坐标。
4-4:2个数,三角形第3个点的坐标。(-3000 <= xi, yi <= 3000)
Output
共T行,对于每组输入数据,相交输出"Yes",否则输出"No"。
Input示例
2
0 0 10
10 0
15 0
15 5
0 0 10
0 0
5 0
5 5
Output示例
Yes
No
#include <iostream>
#include <algorithm>
#include <cstring>
#include <cstdio>
#include <vector>
#include <queue>
#include <cstdlib>
#include <iomanip>
#include <cmath>
#include <cassert>
#include <ctime>
#include <map>
#include <set>
using namespace std;
#define lowbit(x) (x&(-x))
#define max(x,y) (x>y?x:y)
#define min(x,y) (x<y?x:y)
#define MAX 100000000000000000
#define MOD 1000000007
#define pi acos(-1.0)
#define ei exp(1)
#define PI 3.141592653589793238462
#define ios() ios::sync_with_stdio(false)
#define INF 1044266558
#define mem(a) (memset(a,0,sizeof(a)))
typedef long long ll;
ll r,n;
struct Node
{
ll x;
ll y;
}node[];
ll dist(Node a,Node b)
{
return (a.x-b.x)*(a.x-b.x)+(a.y-b.y)*(a.y-b.y);
}
bool check(Node a,Node b)
{
if(((a.y-node[].y)*(a.y-b.y)+(a.x-node[].x)*(a.x-b.x))>=&&((b.y-node[].y)*(b.y-a.y)+(b.x-node[].x)*(b.x-a.x))>=) return true;
return false;
}
int fun(Node a,Node b)
{
if(dist(node[],node[])<r*r && dist(node[],node[])<r*r && dist(node[],node[])<r*r) return ;
else if((dist(node[],node[])<=r*r|| dist(node[],node[])<=r*r || dist(node[],node[])<=r*r) && (dist(node[],node[])>=r*r|| dist(node[],node[])>=r*r || dist(node[],node[])>=r*r)) return ;
else
{
if(((b.y-a.y)*node[].x-node[].y*(b.x-a.x)+b.x*a.y-a.x*b.y)*((b.y-a.y)*node[].x-node[].y*(b.x-a.x)+b.x*a.y-a.x*b.y)>r*r*((b.y-a.y)*(b.y-a.y)+(a.x-b.x)*(a.x-b.x))) return ;
else if(check(a,b)) return ;
}
}
int main()
{
scanf("%lld",&n);
while(n--)
{
scanf("%lld%lld%lld",&node[].x,&node[].y,&r);
for(int i=;i<=;i++)
scanf("%lld%lld",&node[i].x,&node[i].y);
if(fun(node[],node[]) || fun(node[],node[]) || fun(node[],node[])) printf("Yes\n");
else printf("No\n");
}
return ;
}
/*
5
-2 -1 1
1 -2
-1 0
-2 0
0 -1 1
-1 -1
1 1
1 -2
-1 1 1
-2 -2
0 1
-1 -2
-2 -1 1
-1 0
0 0
1 -2
0 -1 1
1 0
1 1
-1 -2
*/
/*
Yes
Yes
Yes
No
Yes
*/

最新文章

  1. Selenium WebDriver 3.0 需要注意的事项
  2. 软件工程(QLGY2015)第三次作业点评(含成绩)
  3. Centos 6.4 32位 gcc 升级(已验证)
  4. (转载整理)SAP ERP常用T-CODE
  5. 利用sklearn计算文本相似性
  6. Navicat for mysql远程连接数据库详(1130错误解决方法)
  7. javax.servlet.ServletException: Servlet execution threw an exception 异常解决之一
  8. BBC 生命大设计
  9. oracle至mysql该指南的数据模式()任意数据源之间的跨导应用
  10. 锋利的KATANA
  11. log4j 在项目中的详细配置
  12. JavaWeb(二)cookie与session的应用
  13. LNMP Yii2 验证码不显示问题最终解决方案
  14. 玄学bug(1)---注释里面的中文会报错
  15. opencv学习之路(24)、轮廓查找与绘制(三)——凸包
  16. 如何在linux下开启FTP服务
  17. 20165227 2017-2018-2《Java程序设计》课程总结
  18. IEnumerable&lt;T&gt;
  19. 程序员必备的代码审查(Code Review)清单
  20. C# -- HttpWebRequest 和 HttpWebResponse 的使用 C#编写扫雷游戏 使用IIS调试ASP.NET网站程序 WCF入门教程 ASP.Net Core开发(踩坑)指南 ASP.Net Core Razor+AdminLTE 小试牛刀 webservice创建、部署和调用 .net接收post请求并把数据转为字典格式

热门文章

  1. Linux-TCP/IP, IPv4地址类别摘要
  2. poj2728 Desert King(最小生成树+01分数规划=最优比率生成树)
  3. 关联Anaconda和最新Pycharm2018.3.2
  4. Java基础学习总结(18)——网络编程
  5. CODEVS——T 2833 奇怪的梦境
  6. 适用于OpenGL离屏渲染上下文的初始化代码
  7. 关于post请求“CAUTION: Provisional headers are shown”【转】
  8. Java中Socket上的Read操作堵塞问题
  9. Ehcache整合spring配置,配置springMVC缓存
  10. 118.类包装器与lambda函数包装器(伪函数实现)