题意:

给三个线段(每个线段的两个端点的坐标),问这三个线段能否组成字母A。

组成字母A的条件:

1.两个线段有公共端点。

2.这两个线段夹角小于等于90度。

3.第三个线段的两个端点分别在这两个线段上,且各自分割的大小比率不超过4:1

思路:

直接。。。。。

应该开始积累计算几何的代码了,,,,

代码:

struct Point{
double x,y;
};
struct segment{
Point a,b;
}
S[5]; bool samePoint(Point a,Point b){
if(fabs(a.x-b.x)<eps && fabs(a.y-b.y)<eps){
return true;
}
return false;
}
bool PointOnSegment(Point a,segment L){
if((a.x-L.a.x)*(L.b.y-L.a.y)==(a.y-L.a.y)*(L.b.x-L.a.x)
&& min(L.a.x,L.b.x)<=a.x && a.x<=max(L.a.x,L.b.x)
&& min(L.a.y,L.b.y)<=a.y && a.y<=max(L.a.y,L.b.y)){
return true;
}
return false;
}
double rates(Point a,segment L){
double l1=(a.x-L.a.x)*(a.x-L.a.x)+(a.y-L.a.y)*(a.y-L.a.y);
double l2=(a.x-L.b.x)*(a.x-L.b.x)+(a.y-L.b.y)*(a.y-L.b.y);
if(l1<eps || l2<eps){
return 999999.0;
}
if(l1<l2){
return l2/l1;
}
else{
return l1/l2;
}
}
ll Cos(double x1,double y1,double x2,double y2){
if(x1*x2+y1*y2>=0){
return true;
}
return false;
}
bool solve(){
//1 and 2
bool t1=samePoint(S[1].a,S[2].a);
bool t2=samePoint(S[1].a,S[2].b);
bool t3=samePoint(S[1].b,S[2].a);
bool t4=samePoint(S[1].b,S[2].b);
if(t1||t2||t3||t4){
bool flag=false;
if(t1){
double x1,y1,x2,y2;
x1=S[1].b.x-S[1].a.x;
y1=S[1].b.y-S[1].a.y;
x2=S[2].b.x-S[2].a.x;
y2=S[2].b.y-S[2].a.y;
if(Cos(x1,y1,x2,y2)){
flag=true;
}
}
if(t2){
double x1,y1,x2,y2;
x1=S[1].b.x-S[1].a.x;
y1=S[1].b.y-S[1].a.y;
x2=S[2].a.x-S[2].b.x;
y2=S[2].a.y-S[2].b.y;
if(Cos(x1,y1,x2,y2)){
flag=true;
}
}
if(t3){
double x1,y1,x2,y2;
x1=S[1].a.x-S[1].b.x;
y1=S[1].a.y-S[1].b.y;
x2=S[2].b.x-S[2].a.x;
y2=S[2].b.y-S[2].a.y;
if(Cos(x1,y1,x2,y2)){
flag=true;
}
}
if(t4){
double x1,y1,x2,y2;
x1=S[1].a.x-S[1].b.x;
y1=S[1].a.y-S[1].b.y;
x2=S[2].a.x-S[2].b.x;
y2=S[2].a.y-S[2].b.y;
if(Cos(x1,y1,x2,y2)){
flag=true;
}
}
if(flag){
if(PointOnSegment(S[3].a,S[1]) && PointOnSegment(S[3].b,S[2])){
if(rates(S[3].a,S[1])<=16.0 && rates(S[3].b,S[2])<=16.0){
return true;
}
}
if(PointOnSegment(S[3].b,S[1]) && PointOnSegment(S[3].a,S[2])){
if(rates(S[3].b,S[1])<=16.0 && rates(S[3].a,S[2])<=16.0){
return true;
}
}
}
} //1 and 3
t1=samePoint(S[1].a,S[3].a);
t2=samePoint(S[1].a,S[3].b);
t3=samePoint(S[1].b,S[3].a);
t4=samePoint(S[1].b,S[3].b);
if(t1||t2||t3||t4){
bool flag=false;
if(t1){
double x1,y1,x2,y2;
x1=S[1].b.x-S[1].a.x;
y1=S[1].b.y-S[1].a.y;
x2=S[3].b.x-S[3].a.x;
y2=S[3].b.y-S[3].a.y;
if(Cos(x1,y1,x2,y2)){
flag=true;
}
}
if(t2){
double x1,y1,x2,y2;
x1=S[1].b.x-S[1].a.x;
y1=S[1].b.y-S[1].a.y;
x2=S[3].a.x-S[3].b.x;
y2=S[3].a.y-S[3].b.y;
if(Cos(x1,y1,x2,y2)){
flag=true;
}
}
if(t3){
double x1,y1,x2,y2;
x1=S[1].a.x-S[1].b.x;
y1=S[1].a.y-S[1].b.y;
x2=S[3].b.x-S[3].a.x;
y2=S[3].b.y-S[3].a.y;
if(Cos(x1,y1,x2,y2)){
flag=true;
}
}
if(t4){
double x1,y1,x2,y2;
x1=S[1].a.x-S[1].b.x;
y1=S[1].a.y-S[1].b.y;
x2=S[3].a.x-S[3].b.x;
y2=S[3].a.y-S[3].b.y;
if(Cos(x1,y1,x2,y2)){
flag=true;
}
}
if(flag){
if(PointOnSegment(S[2].a,S[1]) && PointOnSegment(S[2].b,S[3])){
if(rates(S[2].a,S[1])<=16.0 && rates(S[2].b,S[3])<=16.0){
return true;
}
}
if(PointOnSegment(S[2].b,S[1]) && PointOnSegment(S[2].a,S[3])){
if(rates(S[2].b,S[1])<=16.0 && rates(S[2].a,S[3])<=16.0){
return true;
}
}
}
} //2 and 3
t1=samePoint(S[2].a,S[3].a);
t2=samePoint(S[2].a,S[3].b);
t3=samePoint(S[2].b,S[3].a);
t4=samePoint(S[2].b,S[3].b);
if(t1||t2||t3||t4){
bool flag=false;
if(t1){
double x1,y1,x2,y2;
x1=S[2].b.x-S[2].a.x;
y1=S[2].b.y-S[2].a.y;
x2=S[3].b.x-S[3].a.x;
y2=S[3].b.y-S[3].a.y;
if(Cos(x1,y1,x2,y2)){
flag=true;
}
}
if(t2){
double x1,y1,x2,y2;
x1=S[2].b.x-S[2].a.x;
y1=S[2].b.y-S[2].a.y;
x2=S[3].a.x-S[3].b.x;
y2=S[3].a.y-S[3].b.y;
if(Cos(x1,y1,x2,y2)){
flag=true;
}
}
if(t3){
double x1,y1,x2,y2;
x1=S[2].a.x-S[2].b.x;
y1=S[2].a.y-S[2].b.y;
x2=S[3].b.x-S[3].a.x;
y2=S[3].b.y-S[3].a.y;
if(Cos(x1,y1,x2,y2)){
flag=true;
}
}
if(t4){
double x1,y1,x2,y2;
x1=S[2].a.x-S[2].b.x;
y1=S[2].a.y-S[2].b.y;
x2=S[3].a.x-S[3].b.x;
y2=S[3].a.y-S[3].b.y;
if(Cos(x1,y1,x2,y2)){
flag=true;
}
}
if(flag){
if(PointOnSegment(S[1].a,S[2]) && PointOnSegment(S[1].b,S[3])){
if(rates(S[1].a,S[2])<=16.0 && rates(S[1].b,S[3])<=16.0){
return true;
}
}
if(PointOnSegment(S[1].b,S[2]) && PointOnSegment(S[1].a,S[3])){
if(rates(S[1].b,S[2])<=16.0 && rates(S[1].a,S[3])<=16.0){
return true;
}
}
}
} return false;
} int T;
int main(){ cin>>T;
while(T--){
scanf("%lf%lf%lf%lf",&S[1].a.x,&S[1].a.y,&S[1].b.x,&S[1].b.y);
scanf("%lf%lf%lf%lf",&S[2].a.x,&S[2].a.y,&S[2].b.x,&S[2].b.y);
scanf("%lf%lf%lf%lf",&S[3].a.x,&S[3].a.y,&S[3].b.x,&S[3].b.y);
if(solve()){
puts("YES");
}else{
puts("NO");
}
} return 0;
}

cf13B Letter A(分类+简单计算几何,,)的更多相关文章

  1. CF13B Letter A

    CF13B Letter A 洛谷传送门 题目描述 Little Petya learns how to write. The teacher gave pupils the task to writ ...

  2. ●POJ 1556 The Doors(简单计算几何+最短路)

    ●赘述题目 10*10的房间内,有竖着的一些墙(不超过18个).问从点(0,5)到(10,5)的最短路. 按照输入样例,输入的连续5个数,x,y1,y2,y3,y4,表示(x,0--y1),(x,y2 ...

  3. 2018.07.04 POJ 2398 Toy Storage(二分+简单计算几何)

    Toy Storage Time Limit: 1000MS Memory Limit: 65536K Description Mom and dad have a problem: their ch ...

  4. 2018.07.03 BZOJ 1007: [HNOI2008]水平可见直线(简单计算几何)

    1007: [HNOI2008]水平可见直线 Time Limit: 1 Sec Memory Limit: 162 MB Description 在xoy直角坐标平面上有n条直线L1,L2,-Ln, ...

  5. python - 实现文本分类[简单使用第三方库完成]

    第三方库 pandas sklearn 数据集 来自于达观杯 训练:train.txt 测试:test.txt 概述 TF-IDF 模型提取特征值建立逻辑回归模型 代码 # _*_ coding:ut ...

  6. HDU2948Geometry Darts(简单计算几何)

    题目大意就是说两个人掷飞镖,飞镖在所给定的图形内就记一分,现在给定N个图形(圆.三角形和矩形),问每一次比赛(没人分别掷三次)谁赢. #include <map> #include < ...

  7. Bzoj4558:分类讨论 计算几何 组合数学

    国际惯例的题面: 这题让我爆肝啦......这种计数显然容斥,正好不含任何坏点的我们不会算,但是我们能算至少含零个坏点的,至少含一个坏点的,至少含两个坏点的......所以最终的答案就是(至少含零个坏 ...

  8. 2018.07.04 POJ 1654 Area(简单计算几何)

    Area Time Limit: 1000MS Memory Limit: 10000K Description You are going to compute the area of a spec ...

  9. 2018.07.04 POJ 3304 Segments(简单计算几何)

    Segments Time Limit: 1000MS Memory Limit: 65536K Description Given n segments in the two dimensional ...

随机推荐

  1. Catch That Cow----BFS

    Catch That Cow Description 农夫知道一头牛的位置,想要抓住它.农夫和牛都位于数轴上 ,农夫起始位于点 N(0<=N<=100000) ,牛位于点 K(0<= ...

  2. 【OWASP TOP10】2021年常见web安全漏洞TOP10排行

    [2021]常见web安全漏洞TOP10排行 应用程序安全风险 攻击者可以通过应用程序中许多的不同的路径方式去危害企业业务.每种路径方法都代表了一种风险,这些风险都值得关注. 什么是 OWASP TO ...

  3. Jmeter扩展组件开发(6) - 将响应结果数据显示到查看结果树中

    CODE //用来存储响应数据,目的是将响应结果放到查看结果树当中private String resultData;/** 这个方法就是实现你具体功能逻辑的方法* @param javaSample ...

  4. Centos7 搭建sonarQube

       可以支持包括java,C#,C/C++,PL/SQL,Cobol,JavaScrip,Groovy等等二十几种编程语言的代码质量管理与检测: SonarQube官网:https://www.so ...

  5. linux中创建公私钥

    linux中创建公私钥要再~(root)目录下ssh-keygencd /root/.ssh/lsid_rsa 是私钥id_rsa.pub 是公钥把 authorized_keys删除掉,重新建aut ...

  6. PyCharm中文下载与安装教程【2021年更新】

    第一章:下载与安装 1.1   [版本介绍]多个版本的介绍与选择 Jetbrain 公司是一家专业的 IDE 生产商,只要是市面上主流的编程语言,Jetbrain 都有相应的产品. 比如:Python ...

  7. Redis之品鉴之旅(三)

    3)Set,可以去重的.无序的集合.可以取交集.并集.zset(sorted set),有序的.去重的集合,排序不是根据value排序,而是根据score排序. using (RedisClient ...

  8. Ubuntu 20.04上安装MySQL教程,ubuntu安装mysql

    在Ubuntu 20.04上安装MySQL教程 先决条件 确保您以具有sudo特权的用户身份登录. 在Ubuntu上安装MySQL 在撰写本文时,Ubuntu存储库中可用的MySQL的最新版本是MyS ...

  9. 记一次Kafka服务器宕机的真实经历!!

    大家好,我是冰河~~ 估计节前前祭拜服务器不灵了,年后服务器总是或多或少的出现点问题.不知是人的问题,还是风水问题.昨天下班时,跟运维小伙伴交代了好几遍:如果使用Docker安装Kafka集群的话,也 ...

  10. 拥抱开源,共建生态 - 开源生态与效能提升专场 | CIF 精彩看点

    随着软件技术日新月异的发展,GitHub 已经进化成为人类软件的基因库,遇到问题第一时间在 GitHub 上寻求合适的解决方案,已经逐渐变成工程师处理问题的常见方法.据 GitHub 年度报告显示,2 ...