codeforce gym/100495/problem/K—Wolf and sheep 两圆求相交面积 与 gym/100495/problem/E—Simple sequence思路简述
之前几乎没写过什么这种几何的计算题。在众多大佬的博客下终于记起来了当时的公式。嘚赶快补计算几何和概率论的坑了。。。
这题的要求,在对两圆相交的板子略做修改后,很容易实现。这里直接给出代码。重点的部分有:两圆在相离(或外交)时输出第一个圆的面积、内涵(或内切)则需要分类讨论,是羊的圈大、还是狼的圈大。以下是代码:
#include<iostream>
#include<cmath>
#include<stdio.h>
using namespace std;
int main()
{
double a,b,c,d,e,f,jiao1,jiao2,s1,s2,s3,s4,l,py;
int t,s,j;
py=2*acos(0);
//cout<<py<<endl;
j=1;
cin>>t;
while(t--)
{
cin>>a>>b>>c;
cin>>d>>e>>f;
l=sqrt((d-a)*(d-a)+(e-b)*(e-b));//l是两圆的圆心距
if(l<=fabs(c-f))//如果内涵(切)
{
if(c>f)
{
cout<<"Case #"<<j++<<": ";
printf("%.11lf",py*(c*c-f*f));
cout<<endl;
}
else cout<<"Case #"<<j++<<": "<<"0"<<endl;
continue;
}
else if(l>=c+f)//如果相离(外切)
{
cout<<"Case #"<<j++<<": ";
printf("%.11lf",py*c*c);
cout<<endl;
continue;
}
//以下为一般的相交情况
jiao1=acos((l*l+c*c-f*f)/(2*l*c));//余弦定理求出第一个圆对应圆心角的一半
jiao2=acos((l*l+f*f-c*c)/(2*l*f));//同理求第二个圆
s1=jiao1*c*c;//第一个圆对应的扇形
s2=jiao2*f*f;//第二个圆对应扇形
s3=c*c*sin(jiao1)*cos(jiao1);//第一个圆心角对应的三角形
s4=f*f*sin(jiao2)*cos(jiao2);//第二个圆心角对应的三角形
cout<<"Case #"<<j++<<": ";
printf("%.11lf",py*c*c-(s1+s2-s3-s4));//输出第一个圆的面积减去公共部分面积
cout<<endl;
//cout<<s1+s2-s3-s4<<endl;
//在这里, s1+s2-s3-s4是圆的公共部分面积
}
}
圆心角对应的三角形可能会比较难理解,但只要画一个一般情况的图出来,模拟一边求解过程,就能更好的理解了。
写的时候,我还因为没讨论内切情况而WA2 ,感觉几何的情况要比其他题目的多得多啊。。
然后在这简述一下gym/100495/problem/E—Simple sequence的思路,这题也同样出现在了新生赛里。这题可以用类似尺取法的方式暴力。用两个元素l、r来标记当前段的前后位置,满足条件则尾部往后移动、不满足时就把头往后移动。在把头往后移动之前,需要讨论当前段的头是不是该区间的最大值或者最小追,若答案为是,则需要在移动后的区域里找到最大或最小值。这个暴力方法十分精妙,时间非常的逼近O(n)。很适合作为理解尺取法和区间取数的例题。
代码本来想打的。。但是刚要测试数据的时候Dev卡死了,然后就没了QAQ
codeforce gym/100495/problem/K—Wolf and sheep 两圆求相交面积 与 gym/100495/problem/E—Simple sequence思路简述的更多相关文章
- hdu5858 Hard problem(求两圆相交面积)
题目传送门 Hard problem Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Other ...
- Gym 100952J&&2015 HIAST Collegiate Programming Contest J. Polygons Intersection【计算几何求解两个凸多边形的相交面积板子题】
J. Polygons Intersection time limit per test:2 seconds memory limit per test:64 megabytes input:stan ...
- Codeforces Gym 100610 Problem K. Kitchen Robot 状压DP
Problem K. Kitchen Robot Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/gym/10061 ...
- Gym 101981K - Kangaroo Puzzle - [玄学][2018-2019 ACM-ICPC Asia Nanjing Regional Contest Problem K]
题目链接:http://codeforces.com/gym/101981/problem/K Your friend has made a computer video game called “K ...
- 2010-2011 ACM-ICPC, NEERC, Moscow Subregional Contest Problem K. KMC Attacks 交互题 暴力
Problem K. KMC Attacks 题目连接: http://codeforces.com/gym/100714 Description Warrant VI is a remote pla ...
- Codeforces 1089K - King Kog's Reception - [线段树][2018-2019 ICPC, NEERC, Northern Eurasia Finals Problem K]
题目链接:https://codeforces.com/contest/1089/problem/K time limit per test: 2 seconds memory limit per t ...
- Western Subregional of NEERC, Minsk, Wednesday, November 4, 2015 Problem K. UTF-8 Decoder 模拟题
Problem K. UTF-8 Decoder 题目连接: http://opentrains.snarknews.info/~ejudge/team.cgi?SID=c75360ed7f2c702 ...
- XVII Open Cup named after E.V. Pankratiev Grand Prix of Moscow Workshops, Sunday, April 23, 2017 Problem K. Piecemaking
题目:Problem K. PiecemakingInput file: standard inputOutput file: standard outputTime limit: 1 secondM ...
- 2018 Multi-University Training Contest 4 Problem K. Expression in Memories 【模拟】
任意门:http://acm.hdu.edu.cn/showproblem.php?pid=6342 Problem K. Expression in Memories Time Limit: 200 ...
随机推荐
- thinkphp5中使用PHPExcel(转载)
thinkphp5中可以使用composer来获取第三方类库,使用起来特别方便,例如:可是使用composer下载PHPMailer,think-captcha(验证码)等等…… 接下来说一下怎么使用 ...
- 【Swing程序设计/常用面板】
面板也是一个Swing容器,可以作为容器容纳其他组件,但是它必须要被添加到其他容器中.Swing常见的面板是JPanel面板和JScrollPanel面板. JPanel面板可以聚集一些组件来布局. ...
- fiddler 修改
很多新手学习fiddler抓包的同学们都会对https网站抓包难或者抓不起来的问题无所适从,想寻求解决办法,没问题,这节课就来解决你的疑问! 最典型的网站就是目前的百度网站了,百度在近些年采用了htt ...
- linux vue uwsgi nginx 部署路飞学城 安装 vue
vue+uwsgi+nginx部署路飞学城 有一天,老男孩的苑日天给我发来了两个神秘代码,听说是和mjj的结晶 超哥将这两个代码,放到了一个网站上,大家可以自行下载 路飞学城django代码#这个代码 ...
- 转:sql篇 select from where group by having order by
原文地址: sql篇 select from where group by having order by select from where group by having order by 的基 ...
- jquery基础学习之AJAX篇(五)
理解不深,只知道这么用 jquery 中ajax的请求方法 $.ajax({ url:‘http://...’, //请求网址 type:'GET', //请求方法 success:function( ...
- 洛谷P3178 树上操作 [HAOI2015] 树链剖分
正解:树链剖分+线段树 解题报告: 传送门! 树链剖分+线段树算是基操了趴,,, 就无脑码码码,没有任何含金量,不需要动脑子,然后码量其实也不大,就很爽 比树剖的板子还要板子一些hhhhh 放下代码就 ...
- Android Studio--》Gradle Scripts配置说明
什么是Gradle? Gradle是一种依赖管理工具,基于Groovy语言,面向Java应用为主,它抛弃了基于XML的各种繁琐配置,取而代之的是一种基于Groovy的内部领域特定(DSL)语言. 安装 ...
- python框架之Django(11)-中间件
介绍 在django中,中间件其实就是一个类,在一个请求到来和这个请求结束之前,django会根据自己的规则在合适的时机执行中间件中相应的方法. 在django项目的settings模块中,有一个 M ...
- JAVA设计模式之静态代理
首先看看什么是代理模式. 一 代理模式 使用一个代理对象将对象包装起来,然后用该代理对象来取代该对象,任何对原始对象的调用都要通过代理,代理对象决定是否以及何时调用原始对象的方法 二 静态模式 要求被 ...