首页 > 其他 > 详细

hdu 1071 The area【定积分】

时间:2018-02-17 22:00:21      阅读:236      评论:0      收藏:0      [点我收藏+]

用顶点式\( a(x-h)^2+k=y \)解方程,转化为\(ax^2+bx+c=y \)的形式,然后对二次函数求定积分\( \frac{ax^3}{3}+\frac{bx^2}{2}+cx+C \)即可。(其实我不知道那个C是干什么用的反正这里不用加。

#include<iostream>
#include<cstdio>
using namespace std;
int T;
double x1,x2,x3,y1,y2,y3,a,b,c,h,k;
double f(double x)
{
    return a*x*x*x/3+c*x+x*a*h*h-a*h*x*x-(k*x*x/2+b*x);
}
int main()
{
    scanf("%d",&T);
    while(T--)
    {
        scanf("%lf%lf%lf%lf%lf%lf",&x1,&y1,&x2,&y2,&x3,&y3);
        a=(y2-y1)/(x2-x1)/(x2-x1);
        c=y1;
        h=x1;
        k=(y3-y2)/(x3-x2);
        b=y2-k*x2;
        printf("%.2lf\n",f(x3)-f(x2));
    }
    return 0;
}

hdu 1071 The area【定积分】

原文:https://www.cnblogs.com/lokiii/p/8452221.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!