湖南省第十二届大学生计算机程序设计竞赛$J$题

计算几何。

  1. #pragma comment(linker, "/STACK:1024000000,1024000000")
  2. #include<cstdio>
  3. #include<cstring>
  4. #include<cmath>
  5. #include<algorithm>
  6. #include<vector>
  7. #include<map>
  8. #include<set>
  9. #include<queue>
  10. #include<stack>
  11. #include<iostream>
  12. using namespace std;
  13. typedef long long LL;
  14. const double pi=acos(-1.0),eps=1e-;
  15. void File()
  16. {
  17. freopen("D:\\in.txt","r",stdin);
  18. freopen("D:\\out.txt","w",stdout);
  19. }
  20. template <class T>
  21. inline void read(T &x)
  22. {
  23. char c = getchar();
  24. x = ;
  25. while(!isdigit(c)) c = getchar();
  26. while(isdigit(c))
  27. {
  28. x = x * + c - '';
  29. c = getchar();
  30. }
  31. }
  32.  
  33. const int maxn=;
  34. const int maxisn=;
  35.  
  36. int dcmp(double x)
  37. {
  38. if(x>eps) return ;
  39. return x<-eps ? - : ;
  40. }
  41. inline double Sqr(double x)
  42. {
  43. return x*x;
  44. }
  45. struct Point
  46. {
  47. double x,y;
  48. Point()
  49. {
  50. x=y=;
  51. }
  52. Point(double x,double y):x(x),y(y) {};
  53. friend Point operator + (const Point &a,const Point &b)
  54. {
  55. return Point(a.x+b.x,a.y+b.y);
  56. }
  57. friend Point operator - (const Point &a,const Point &b)
  58. {
  59. return Point(a.x-b.x,a.y-b.y);
  60. }
  61. friend bool operator == (const Point &a,const Point &b)
  62. {
  63. return dcmp(a.x-b.x)==&&dcmp(a.y-b.y)==;
  64. }
  65. friend Point operator * (const Point &a,const double &b)
  66. {
  67. return Point(a.x*b,a.y*b);
  68. }
  69. friend Point operator * (const double &a,const Point &b)
  70. {
  71. return Point(a*b.x,a*b.y);
  72. }
  73. friend Point operator / (const Point &a,const double &b)
  74. {
  75. return Point(a.x/b,a.y/b);
  76. }
  77. friend bool operator < (const Point &a, const Point &b)
  78. {
  79. return a.x < b.x || (a.x == b.x && a.y < b.y);
  80. }
  81. inline double dot(const Point &b)const
  82. {
  83. return x*b.x+y*b.y;
  84. }
  85. inline double cross(const Point &b,const Point &c)const
  86. {
  87. return (b.x-x)*(c.y-y)-(c.x-x)*(b.y-y);
  88. }
  89.  
  90. };
  91.  
  92. Point LineCross(const Point &a,const Point &b,const Point &c,const Point &d)
  93. {
  94. double u=a.cross(b,c),v=b.cross(a,d);
  95. return Point((c.x*v+d.x*u)/(u+v),(c.y*v+d.y*u)/(u+v));
  96. }
  97. double PolygonArea(Point p[],int n)
  98. {
  99. if(n<) return 0.0;
  100. double s=p[].y*(p[n-].x-p[].x);
  101. p[n]=p[];
  102. for(int i=; i<n; i++)
  103. {
  104. s+=p[i].y*(p[i-].x-p[i+].x);
  105. }
  106. return fabs(s*0.5);
  107. }
  108. double CPIA(Point a[],Point b[],int na,int nb)
  109. {
  110. Point p[maxisn],temp[maxisn];
  111. int i,j,tn,sflag,eflag;
  112. a[na]=a[],b[nb]=b[];
  113. memcpy(p,b,sizeof(Point)*(nb+));
  114. for(i=; i<na&&nb>; ++i)
  115. {
  116. sflag=dcmp(a[i].cross(a[i+],p[]));
  117. for(j=tn=; j<nb; ++j,sflag=eflag)
  118. {
  119. if(sflag>=) temp[tn++]=p[j];
  120. eflag=dcmp(a[i].cross(a[i+],p[j+]));
  121. if((sflag^eflag)==-)
  122. temp[tn++]=LineCross(a[i],a[i+],p[j],p[j+]);
  123. }
  124. memcpy(p,temp,sizeof(Point)*tn);
  125. nb=tn,p[nb]=p[];
  126. }
  127. if(nb<) return 0.0;
  128. return PolygonArea(p,nb);
  129. }
  130. double SPIA(Point a[],Point b[],int na,int nb)
  131. {
  132. int i,j;
  133. Point t1[],t2[];
  134. double res=0.0,if_clock_t1,if_clock_t2;
  135. a[na]=t1[]=a[];
  136. b[nb]=t2[]=b[];
  137. for(i=; i<na; i++)
  138. {
  139. t1[]=a[i-],t1[]=a[i];
  140. if_clock_t1=dcmp(t1[].cross(t1[],t1[]));
  141. if(if_clock_t1<) swap(t1[],t1[]);
  142. for(j=; j<nb; j++)
  143. {
  144. t2[]=b[j-],t2[]=b[j];
  145. if_clock_t2=dcmp(t2[].cross(t2[],t2[]));
  146. if(if_clock_t2<) swap(t2[],t2[]);
  147. res+=CPIA(t1,t2,,)*if_clock_t1*if_clock_t2;
  148. }
  149. }
  150. return res;
  151. }
  152.  
  153. Point a[],b[];
  154. Point aa[],bb[];
  155.  
  156. int main()
  157. {
  158. int n1,n2;
  159. double x1,y1,x2,y2,x3,y3,x4,y4;
  160. while(~scanf("%lf%lf%lf%lf%lf%lf%lf%lf",&x1,&y1,&x2,&y2,&x3,&y3,&x4,&y4))
  161. {
  162. n1=,n2=;
  163. a[].x=x1; a[].y=y1;
  164. a[].x=x1; a[].y=y2;
  165. a[].x=x2; a[].y=y1;
  166.  
  167. b[].x=x3; b[].y=y3;
  168. b[].x=x3; b[].y=y4;
  169. b[].x=x4; b[].y=y4;
  170. b[].x=x4; b[].y=y3;
  171.  
  172. printf("%.6lf\n",abs(SPIA(a,b,n1,n2)));
  173. }
  174. return ;
  175. }

CSU 1812 三角形和矩形的更多相关文章

  1. csu 1812: 三角形和矩形 凸包

    传送门:csu 1812: 三角形和矩形 思路:首先,求出三角形的在矩形区域的顶点,矩形在三角形区域的顶点.然后求出所有的交点.这些点构成一个凸包,求凸包面积就OK了. /************** ...

  2. 使用原生JavaScript的Canvas实现拖拽式图形绘制,支持画笔、线条、箭头、三角形、矩形、平行四边形、梯形以及多边形和圆形,不依赖任何库和插件,有演示demo

    前言 需要用到图形绘制,没有找到完整的图形绘制实现,所以自己实现了一个 - - 一.实现的功能 1.基于oop思想构建,支持坐标点.线条(由坐标点组成,包含方向).多边形(由多个坐标点组成).圆形(包 ...

  3. 计算几何板子题【2019牛客国庆集训派对day7——三角形和矩形】【多边形相交的面积】

    链接:https://ac.nowcoder.com/acm/contest/1112/J来源:牛客网 题目描述 Bobo 有一个三角形和一个矩形,他想求他们交的面积. 具体地,三角形和矩形由 8 个 ...

  4. canvas快速绘制圆形、三角形、矩形、多边形

    想看前面整理的canvas常用API的同学可以点下面: canvas学习之API整理笔记(一) canvas学习之API整理笔记(二) 本系列文章涉及的所有代码都将上传至:项目代码github地址,喜 ...

  5. CoreGraphics-基本图形绘制-直线、三角形、矩形、椭圆形、弧形

    框架:CoreGraphics 步骤: 1."获取"图形上下文     let cxtRef = UIGraphicsGetCurrentContext()! 2.添加路径 3.渲 ...

  6. 30.编写一个Shape类,具有属性:周长和面积; 定义其子类三角形和矩形,分别具有求周长的方法。 定义主类E,在其main方法中创建三角形和矩形类的对象, 并赋给Shape类的对象a、b,使用对象a、b来测试其特性。

    package zuoye8; public abstract class Shape { private double zhouchang ; private double mianji ; pub ...

  7. 编写一个Shape类,具有属性:周长和面积; 定义其子类三角形和矩形,分别具有求周长的方法。 定义主类E,在其main方法中创建三角形和矩形类的对象, 并赋给Shape类的对象a、b,使用对象a、b来测试其特性。

    package shape; public class Shape { //定义成员变量 private double zhouchang; private double mianji; public ...

  8. 自定义tabpageindicator,可以自定义tab是三角形还是矩形,但是tab不具有滑动的功能

    我是不会滴,但是看了一些大神写的,我修改了一下,大家可以参照参照 一,自定义Mytabpageindicator,直接贴代码了,具体的在代码中有注释 package com.wangy.mytabpa ...

  9. iOS开发UI-利用Quartz2D 实现基本绘图(画三角形、矩形、圆、圆弧)

    1.画三角形  运行结果如下 1.1具体实现步骤 1.1.1首先新建一个project,然后自定义一个view 1.2代码 #import "htingShapeView.h" @ ...

随机推荐

  1. Bootstrap3.0入门学习系列

    Bootstrap3.0入门学习系列规划[持续更新]   前言 首先在此多谢博友们在前几篇博文当中给与的支持和鼓励,以及在回复中提出的问题.意见和看法. 在此先声明一下,之前在下小菜所有的随笔文章中, ...

  2. HashTable

    算法打基础——HashTable 这一节主要讲很多方面非常重要的hash table等问题. 由于平时很少用到这些,基本都忘了... 怎样快速的在内存中插入.删除.和搜索呢? 这就需要哈希表了 这一节 ...

  3. .NET程序集1

    谈谈.NET程序集(一) 谈谈.NET程序集(一) The Assembly in .NET by 唐小崇 http://www.cnblogs.com/tangchong 在.NET出现之前, Wi ...

  4. asp.net mvc4设置area里面使用相同的 Controller 名称并设置area里的页面为起始页

    asp.net mvc4设置area里面使用相同的 Controller 名称并设置area里的页面为起始页 1.使用重名controller 在asp.net mvc2以后的版本里面,有了area( ...

  5. 提高Java代码质量的Eclipse插件之Checkstyle的使用详解

    提高Java代码质量的Eclipse插件之Checkstyle的使用详解 CheckStyle是SourceForge下的一个项目,提供了一个帮助JAVA开发人员遵守某些编码规范的工具.它能够自动化代 ...

  6. MongoDB安装心得

    本人纯前端一枚,对于数据库安装各种纠结,出了不少错误,一一列出,方便遇到同样问题的人给以参考,也加深一下自己印象. 故事开始了...Node.js在前端界比较火,由于我也是小小前端,跟随大潮流开始步入 ...

  7. Chrome使用小技巧-多用户登录、直接打开隐身模式窗口

    在开发过程中,有时候需要打开2个chrome,各自登录一个账号来做测试,正常情况下由于同一用户下的chrome共享cookies的原因,是没办法登录2个账号的. 这种情况,可以找到chrome图标,点 ...

  8. OC之方法的声明实现和调用

    1. 类是来描述一群具有相同特征和行为的事物的. 类还有行为. 类的声明 @interface 类名 : NSObject { 属性. } 方法的声明 @end 类的实现. @implementati ...

  9. asp.net小技巧:保留password模式文本框textbox内的数据不丢失。

    在asp.net 2.0环境下,使用textbox,提交到服务器再传回,如果textbox是password模式的,那么textbox内的密码(星号.圆点),就没有了! 一个可行的做法是 : prot ...

  10. IOS之frame和bounds区别

    用最简单的语言来解释就是:setFrame和setBounds都是为了把子view加载到父view上去,但设置的参数坐标系不同,setFrame是该view在父view坐标系统中的位置和大小,setB ...