hdu_2056 Rectangles (计算几何)

http://acm.hdu.edu.cn/showproblem.php?pid=2056


分析:

 s1:将矩形对角顶点统一转为左下角和右上角;

 s2:求出相交矩形的左下角和右下角坐标

 s3:求相交部分面积(有可能不存在)

代码:

#include<iostream>
#include<cstdio>
using namespace std;

int main()
{
  double x1,y1,x2,y2;
  double x3,y3,x4,y4;
  while(cin>>x1>>y1>>x2>>y2>>x3>>y3>>x4>>y4){
        if(x1>x2)  swap(x1,x2);
        if(y1>y2)  swap(y1,y2); 
        if(x3>x4)  swap(x3,x4);
        if(y3>y4)  swap(y3,y4);
        x1=x1>x3 ?x1 :x3;
        x2=x2<x4 ? x2: x4;
        y1=y1>y3 ? y1:y3;
        y2=y2<y4 ? y2:y4;
         /*x1=max(x1,x3);
        y1=max(y1,y3);
        x2=min(x2,x4); 
       y2=min(y2,y4);*/
        printf("%.2lf\n",x1<x2&&y1<y2 ? (x2-x1)*(y2-y1):0);
  }
  return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值