UVA 12535 Probability Through Experiments 解题报告

该博客介绍了UVA 12535编程竞赛题目,主要探讨如何计算圆周上可以构成锐角三角形的组合数量。通过设定三角形顶点A、B、C,并分析钝角和直角三角形的条件,得出解决方案:枚举点C,在特定角度范围内选取A和B点。同时,博主提醒注意处理角度超过180度及精度问题。
摘要由CSDN通过智能技术生成

比赛

题目

题意:

一个圆的圆周上有一些点,求能组成的锐角三角形的个数。

题解:

一个在圆上的三角形,按顺时针方向设点为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-6
double 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;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值