UVA 12535 Probability Through Experiments 解题报告
来源:互联网 发布:什么是软件外包公司 编辑:程序博客网 时间:2024/04/30 08:11
比赛
题目
题意:
一个圆的圆周上有一些点,求能组成的锐角三角形的个数。
题解:
一个在圆上的三角形,按顺时针方向设点为A、B、C。如果是钝角三角形,则圆周上A到C的角小于180,如果是直角,则圆周上A到C的角等于180,B的位置随意,在AC间就行。所以可以根据此计算钝角三角形和直角三角形的个数:枚举C点,在[C,C+180]范围内选两个点做AB。注意C大于180度时的情况,就在[C,360]和[0,C-180]中选。
注意EPS的问题
//Time:175ms//Memory:0KB//Length:1033B#include <iostream>#include <cstdio>#include <cstdlib>#include <cstring>#include <cmath>#include <algorithm>using namespace std;#define MAXN 20010#define MAXM 100010#define EPS 1e-6double si[MAXN];int bs(int r,double key){ int l=0,mid; --r; while(l<r) { mid=(l+r+1)/2; if(si[mid]>key+EPS) r=mid-1; else l=mid; } if(si[l]>key+EPS) return -1; return l;}int main(){ //freopen("/home/moor/Code/input","r",stdin); int n,m,cnt=0; long long ans=0; while(scanf("%d%d",&n,&m)==2) { ans=0; if(n==0&&m==0) break; printf("Case %d: ",++cnt); for(int i=0;i<n;++i) scanf("%lf",&si[i]); sort(si,si+n); for(int i=0;i<n;++i) { long long tmp; if(si[i]<180-EPS) tmp=bs(n,180+si[i]+EPS)-i; else tmp=n-i+bs(n,si[i]-180+EPS); ans+=tmp*(tmp-1)/2; } cout<<((long long)n*(n-1)/2*(n-2)/3-ans)<<'\n'; } return 0;}
- UVA 12535 Probability Through Experiments 解题报告
- Probability Through Experiments
- Probability Through Experiments
- Probability Through Experiments
- LA6142 Probability Through Experiments 统计圆上的锐角三角形
- UVAL 6142 Probability Through Experiments 二分搜索 组合数
- 10056 - What is the Probability ? 解题报告
- UVA 10878 解题报告
- UVA 10815 解题报告
- UVA 10010 解题报告
- UVA 10115 解题报告
- UVA 10361 解题报告
- UVA 537 解题报告
- UVA 409 解题报告
- UVA 644 解题报告
- UVA 10494 解题报告
- UVA 424 解题报告
- UVA 10106 解题报告
- openstack 工作原理分析
- 将某字段的值显示为数字
- iOS: UIScrollView的属性contentInset
- POJ 2773 happy2006 (素因子分解+容斥原理+二分)
- 常用的正则表达式应用
- UVA 12535 Probability Through Experiments 解题报告
- iOS: UIScrollView的属性contentOffset
- Java---多线程断点下载
- uImage和zImage
- hdu 3516 四边形优化dp
- iOS: UIScrollView的属性decelerating
- HHVM(HipHop PHP)优化加速PHP代码:搭建提速五六倍的PHP服务器
- [leetcode刷题系列]Triangle
- hdu-Lowest Common Multiple Plus(瑕疵版)