题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4752

题意:给出一个抛物线和一个简单多边形。求抛物线在多边形内部的长度。

思路:首先求出多边形所有边和抛物线的交点。这里要注意:

(1)边和抛物线相切不算,因为整个抛物线在边的另一侧;

(2)如下,上面两种相交都是不能算的,下面一种要算。

算出所有交点之后,那么每相邻两个交点与抛物线的关系必然是抛物线交替进入-离开。下面对于一段[x1,x2]计算抛物线的长度。

struct point
{
    double x,y;

    void get()
    {
        cin>>x>>y;
    }

    point(){}
    point(double _x,double _y)
    {
        x=_x;
        y=_y;
    }

    point operator+(point a)
    {
        return point(x+a.x,y+a.y);
    }

    point operator-(point a)
    {
        return point(x-a.x,y-a.y);
    }

    point operator*(double t)
    {
        return point(x*t,y*t);
    }
};

point p[N];
int n;
double L,R,a,b,c;

int sgn(double x)
{
    if(x>1e-8) return 1;
    if(x<-1e-8) return -1;
    return 0;
}

vector<double> V;

double func(double x)
{
    return a*x*x+b*x+c;
}

void deal(point p,point q)
{

    if(sgn(p.x-q.x)==0)
    {
        double y=func(p.x);
        if(p.y>q.y) swap(p,q);
        if(sgn(y-p.y)>0&&sgn(y-q.y)<0) V.pb(p.x);
        return;
    }

    double k=(q.y-p.y)/(q.x-p.x);
    double A=a;
    double B=b-k;
    double C=c+k*p.x-p.y;
    double temp=B*B-4*A*C;
    if(sgn(temp)<=0) return;
    temp=sqrt(temp);
    double x1=(-B-temp)/(2*A);
    double x2=(-B+temp)/(2*A);
    if(p.x>q.x) swap(p,q);
    if(sgn(x1-p.x)>0&&sgn(x1-q.x)<0) V.pb(x1);
    if(sgn(x2-p.x)>0&&sgn(x2-q.x)<0) V.pb(x2);
}

void deal(point p1,point p,point p2)
{
    if(sgn(func(p.x)-p.y)) return;
    p1=p+(p1-p)*1e-3;
    p2=p+(p2-p)*1e-3;
    if(sgn(func(p1.x)-p1.y)*sgn(func(p2.x)-p2.y)==-1) V.pb(p.x);
}

double cal(double x)
{
    double A=4*a*a;
    double B=4*a*b;
    double C=b*b+1;

    double temp=A*x*x+B*x+C;
    return (2*A*x+B)/(4*A)*sqrt(temp)+(4*A*C-B*B)/(8*A*sqrt(A))*log(fabs(2*A*x+B+2*sqrt(A)*sqrt(temp)));
}

double cal(double l,double r)
{
    if(l<L) l=L;
    if(r>R) r=R;
    if(l>=r) return 0;
    return cal(r)-cal(l);
}

int main()
{
    Rush(n)
    {
        scanf("%lf%lf%lf%lf%lf",&a,&b,&c,&L,&R);
        int i;
        FOR0(i,n) p[i].get();
        p[n]=p[0]; p[n+1]=p[1];
        V.clear();
        FOR0(i,n) deal(p[i],p[i+1]);
        FOR1(i,n) deal(p[i-1],p[i],p[i+1]);
        sort(V.begin(),V.end());
        double ans=0;
        for(i=0;i+1<SZ(V);i+=2) ans+=cal(V[i],V[i+1]);
        PR(ans);
    }
}

  

HDU 4752 Polygon(抛物线长度积分)的更多相关文章

  1. hdu 4969 Just a Joke(积分)

    题目链接:hdu 4969 Just a Joke 题目大意:Guizeyanhua要去追一个女孩,女孩在以Guizeyanhua为圆心,半径为R的圆上匀速运动,女孩的速度为v1,Guizeyanhu ...

  2. hdu 1724 Ellipse —— 自适应辛普森积分

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=1724 函数都给出来了,可以用辛普森积分: 一开始 eps = 1e-8 TLE了,答案只要三位小数,那么 ...

  3. HDU 1724 Ellipse (自适应辛普森积分)

    题目链接:HDU 1724 Problem Description Math is important!! Many students failed in 2+2's mathematical tes ...

  4. hdu 4033Regular Polygon(二分+余弦定理)

    Regular Polygon Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65768/65768 K (Java/Others)T ...

  5. HDU 3668 Volume (数学,积分)

    题意:求图中交叉圆柱体的体积! 析:大体思路很明确,把两个圆柱的体积加起来 减去中间公共部分的即可!第一步首先得想到公共部分是一个怎样的图形.这个在高数下册例题中有讲到! 中间实线部分就是第一卦限内的 ...

  6. hdu 4752

    计算几何+数值计算的题目: 要用到辛普森积分,没有学过~~~ 参考学习了acm_Naruto大神 的代码! 代码: #include<cstdio> #include<cmath&g ...

  7. HDU 1724 Ellipse 自适应simpson积分

    simpson公式是用于积分求解的比较简单的方法(有模板都简单…… 下面是simpson公式(很明显 这个公式的证明我并不会…… (盗图…… 因为一段函数基本不可能很规则 所以我们要用自适应积分的方法 ...

  8. hdu 5826 physics (物理数学,积分)

    physics Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Sub ...

  9. HDU 3191 次短路长度和条数

    http://www.cnblogs.com/wally/archive/2013/04/16/3024490.html http://blog.csdn.net/me4546/article/det ...

随机推荐

  1. html公用库

    <script src="http://lib.sinaapp.com/js/jquery/1.6/jquery.min.js" language="javascr ...

  2. 版本控制 - SVN/TortoiseSVN

    研读了blog: 1. http://www.open-open.com/lib/view/open1346982569725.html  2. http://www.360doc.com/conte ...

  3. ios 判断空字符串

    - (BOOL) isBlankString:(NSString *)string { if (string == nil || string == NULL) { return YES; } if ...

  4. ObjC的Block中使用weakSelf/strongSelf @weakify/@strongify

    首先要说说什么时候使用weakSelf和strongSelf. 下面引用一篇博客<到底什么时候才需要在ObjC的Block中使用weakSelf/strongSelf>的内容: Objec ...

  5. ios设备突破微信小视频6S限制的方法

    刷微信朋友圈只发文字和图片怎能意犹未竟,微信小视频是一个很好的补充,音视频到位,流行流行最流行.但小视频时长不能超过6S,没有滤镜等是很大的遗憾.but有人突破限制玩出了花样,用ios设备在朋友圈晒出 ...

  6. 用linux服务器下的/dev/shm/来释放磁盘的压力

    巧用linux服务器下的/dev/shm/来释放磁盘的压力 浏览:646 | 更新:2013-06-18 18:08 | 标签: 磁盘 tmpfs是Linux/Unix系统上的一种基于内存的文件系统. ...

  7. 使用 polyfills 的简易方法

    本文作者为 Andrew Betts 与 Robert Nyman.Andrew 是金融时报(Financial Times)实验室主任,该实验室旨在金融时报开发并推广实践性的 Web 技术.Robe ...

  8. main函数和启动例程

    为什么汇编程序的入口是_start,而C程序的入口是main函数呢?本节就来解释这个问题.在讲例 18.1 “最简单的汇编程序”时,我们的汇编和链接步骤是: $ as hello.s -o hello ...

  9. Jsp helloWorld

    <%@ page language="java" contentType="text/html; charset=ISO-8859-1" pageEnco ...

  10. 【剑指offer】和为S的连续整数序列

    找到所有和为S的连续整数序列,序列长度>=2 我的思路:数学法,限定首元素范围,计算序列长度. 书上解法:用small和big两个游标记录序列的开始和结束位置,调整游标. 我的解法: /* ​直 ...