受该两块木板以形成槽的效果。Q槽可容纳雨水多,注意雨爆跌,思想是非常easy,分类讨论是有点差。

1.假定两条线段不相交或平行,然后再装0;

2.有一个平行x轴。连衣裙0。

3.若上面覆盖以下的,装0;

4.其他,叉积求面积。

直接上代码:

#include <iostream>
#include <cmath>
#include <stdio.h> using namespace std; const double eps=1e-8; struct point{
double x;
double y;
}; struct line{
point a;
point b;
}l1,l2; double ans; //求叉积
double xmult(point p0 ,point p1 ,point p2){
return (p1.x-p0.x)*(p2.y-p0.y)-(p2.x-p0.x)*(p1.y-p0.y);
}
int dblcmp(double n){
if(fabs(n)<eps) return 0;
return n>0?1:-1;
}
//推断是否相交。怎样相交
int judge(line l1 ,line l2){
double d1=dblcmp(max(l1.a.x,l1.b.x)-min(l2.a.x,l2.b.x));
double d2=dblcmp(max(l2.a.x,l2.b.x)-min(l1.a.x,l1.b.x));
double d3=dblcmp(max(l1.a.y,l1.b.y)-min(l2.a.y,l2.b.y));
double d4=dblcmp(max(l2.a.y,l2.b.y)-min(l1.a.y,l1.b.y));
double d5=dblcmp(xmult(l2.a,l1.a,l1.b));
double d6=dblcmp(xmult(l2.b,l1.a,l1.b));
double d7=dblcmp(xmult(l1.a,l2.a,l2.b));
double d8=dblcmp(xmult(l1.b,l2.a,l2.b));
if(d1>=0&&d2>=0&&d3>=0&&d4>=0){
if(d5*d6>0||d7*d8>0) return 0;//不相交
else if(d5==0&&d6==0) return 1;//共线相交
else if(d5==0||d6==0||d7==0||d8==0) return 2;//端点相交
else return 3;//规范相交
}
return 0;
} //求斜率
bool getslope(line l ,double &k){
double t=l.a.x-l.b.x;
if(t==0) return false;
k=(l.a.y-l.b.y)/t;
return true;
} //求线段交点
point getIntersect(line l1, line l2) {
point p;
double A1 = l1.b.y - l1.a.y;
double B1 = l1.a.x - l1.b.x;
double C1 = (l1.b.x - l1.a.x) * l1.a.y - (l1.b.y - l1.a.y) * l1.a.x;
double A2 = l2.b.y - l2.a.y;
double B2 = l2.a.x - l2.b.x;
double C2 = (l2.b.x - l2.a.x) * l2.a.y - (l2.b.y - l2.a.y) * l2.a.x;
p.x = (C2*B1 - C1*B2) / (A1*B2 - A2*B1);
p.y = (C1*A2 - C2*A1) / (A1*B2 - A2*B1);
if(p.x==-0) p.x=0;
return p;
} //求a,b两点中y坐标更大的点
point getbiggerY(point a ,point b){
point q;
if (dblcmp(a.y-b.y) > 0) {
q.x = a.x;
q.y = a.y;
} else {
q.x = b.x;
q.y = b.y;
}
return q;
} double getarea(point p ,point p1 ,point p2){
point q;
double a;
if(dblcmp(p1.y-p2.y)>=0) {
q.y = p2.y;
q.x = p.x+(p1.x-p.x)*(p2.y-p.y) / (p1.y-p.y); //求还有一点的坐标
a=fabs(xmult(p, p2, q)) / 2; //叉积求面积
}
else {
q.y = p1.y;
q.x = p.x+(p2.x-p.x)*(p1.y-p.y) / (p2.y-p.y);
a=fabs(xmult(p, p1, q)) / 2;
}
return a;
} int main()
{
int t;
cin>>t;
while(t--){
point p1 ,p2 ,p;
cin>>l1.a.x>>l1.a.y>>l1.b.x>>l1.b.y;
cin>>l2.a.x>>l2.a.y>>l2.b.x>>l2.b.y;
if(judge(l1,l2)<=1)//是否相交
ans=0;
else{
p1=getbiggerY(l1.a ,l1.b);
p2=getbiggerY(l2.a ,l2.b);
p=getIntersect(l1 ,l2);
if(!dblcmp(p.x-p1.x)&&!dblcmp(p.y-p1.y) || !dblcmp(p.x-p2.x)&&!dblcmp(p.x-p2.y))//开口方向
ans=0;
else{
double k1 ,k2;
bool f1 ,f2;
f1 = getslope(l1, k1);
f2 = getslope(l2, k2);
if (!dblcmp(k1) || !dblcmp(k2)) ans=0;
else if (f1 && f2) {//假设两条线都不与y轴平行
if (dblcmp(k1*k2) > 0) { //当两条线段的斜率符号同样时。
int d1 = dblcmp(k1-k2);
int d2 = dblcmp(k2);
if (d1>0&&d2>0&&dblcmp(p2.x-p1.x)*dblcmp(p2.x-p.x)<=0
|| d1<0&&d2>0&&dblcmp(p1.x-p2.x)*dblcmp(p1.x-p.x)<= 0
|| d1>0&&d2<0&&dblcmp(p1.x-p2.x)*dblcmp(p1.x-p.x)<= 0
|| d1<0&&d2<0&&dblcmp(p2.x-p1.x)*dblcmp(p2.x-p.x)<= 0)//覆盖情况
ans = 0;
else
ans=getarea(p,p1,p2);
}
else
ans=getarea(p,p1,p2);
}
else
ans=getarea(p,p1,p2);
}
}
printf ("%.2lf\n", ans);
}
return 0;
}

版权声明:本文博客原创文章。博客,未经同意,不得转载。

POJ 2826 An Easy Problem?! 好的标题的更多相关文章

  1. POJ 2826 An Easy Problem? 判断线段相交

    POJ 2826 An Easy Problem?! -- 思路来自kuangbin博客 下面三种情况比较特殊,特别是第三种 G++怎么交都是WA,同样的代码C++A了 #include <io ...

  2. POJ 2826 An Easy Problem?!

    An Easy Problem?! Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 7837   Accepted: 1145 ...

  3. POJ 2826 An Easy Problem?![线段]

    An Easy Problem?! Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 12970   Accepted: 199 ...

  4. POJ 2826 An Easy Problem?! --计算几何,叉积

    题意: 在墙上钉两块木板,问能装多少水.即两条线段所夹的中间开口向上的面积(到短板的水平线截止) 解法: 如图: 先看是否相交,不相交肯定不行,然后就要求出P与A,B / C,D中谁形成的向量是指向上 ...

  5. POJ 2826 An Easy Problem!(简单数论)

    Description Have you heard the fact "The base of every normal number system is 10" ? Of co ...

  6. 简单几何(线段相交) POJ 2826 An Easy Problem?!

    题目传送门 题意:两条线段看成两块木板,雨水从上方往下垂直落下,问能接受到的水的体积 分析:恶心的分类讨论题,考虑各种情况,尤其是入口被堵住的情况,我的方法是先判断最高的两个点是否在交点的同一侧,然后 ...

  7. POJ 2826 An Easy Problem?!(线段交点+简单计算)

    Description It's raining outside. Farmer Johnson's bull Ben wants some rain to water his flowers. Be ...

  8. POJ 1152 An Easy Problem! (取模运算性质)

    题目链接:POJ 1152 An Easy Problem! 题意:求一个N进制的数R.保证R能被(N-1)整除时最小的N. 第一反应是暴力.N的大小0到62.发现当中将N进制话成10进制时,数据会溢 ...

  9. [POJ] 2453 An Easy Problem [位运算]

    An Easy Problem   Description As we known, data stored in the computers is in binary form. The probl ...

随机推荐

  1. NET Core R2跑Hello World

    在CentOS 7上安装.NET Core R2跑Hello World 前言 在上个月.NET Core出了最新版本预览版,只是在Window系统上试验了一下.原本想等发布正式版的时候在linux系 ...

  2. Java EE登陆界面生成随机数防止恶意注册或者登录

    package cn.com; import java.awt.Color; import java.awt.Font; import java.awt.Graphics; import java.a ...

  3. IMAP和POP3有什么差别?

    servCode=6010376">POP3协议同意电子邮件client下载server上的邮件,可是在client的操作(如移动邮件.标记已读等),不会反馈到server上.比方通过 ...

  4. sharepoint具体错误提示

    sharepoint页面发生错误时,默认不会显示具体错误信息,只显示“未知错误”提示.需要修改配置站点的webconfig文件,才能显示出具体错误提示.具体方法如下: 将safeMode中的CallS ...

  5. iOS- 如何集成支付宝

    链接地址:http://www.cnblogs.com/qingche/p/3556365.html 现在不少app内都集成了支付宝功能   使用支付宝进行一个完整的支付功能,大致有以下步骤: 1&g ...

  6. 14.10.1 InnoDB Disk I/O

    14.10 InnoDB Disk IO and File Space Management InnoDB 磁盘IO和文件空间管理: 14.10.1 InnoDB Disk I/O 14.10.2 F ...

  7. Swift - 多层无缝循环滚动背景(SpriteKit游戏开发)

    在游戏开发中,比如跑酷游戏.我们需要实现背景的无限循环滚动,来营造运动的效果.除了单层的背景滚动,还有视差滚动. 视差滚动是指让多层背景以不同的速度移动,形成立体的效果,从而带来非常出色的视觉体验. ...

  8. 基于android的实时音频频谱仪

    前一段实习,本来打算做c++,到了公司发现没啥项目,于是乎转行做了android,写的第一个程序竟然要我处理信号,咱可是一心搞计算机的,没接触过信号的东西,什么都没接触过,于是乎, 找各种朋友,各种熟 ...

  9. 刚開始学习的人制作VMOS场效应管小功放

    VMOS场效应管既有电子管的长处又有晶体管的长处,用它制作的功率放大器声音醇厚.甜美,动态范围大.频率响应好.因此近年来在音响设备中得到了广泛应用. 大功率的场效应管功率放大器.电.路比較复杂.制作和 ...

  10. eclipse之The currrently displayed page contains invalid values错误

    现象: eclipse的preferences里面须要保存密码,保存报错Could Not Accept ChangesThe currrently displayed page contains i ...