bzoj 2876: [Noi2012]骑行川藏【拉格朗日乘数法+二分】

详见:

http://blog.csdn.net/popoqqq/article/details/42366599

http://blog.csdn.net/whzzt/article/details/51346228

用拉格朗日乘数法,求了偏导之后二分λ。然后求完偏导的那个一元三次式的解可以二分求,因为是单调递增的。

总复杂度\( O(nlog^2n) \)

#include<cstdio>
#include<cmath>
using namespace std;
const int N=120005;
int n,q,op,i,m;
double X1,X2,Y1,Y2,a,b,c,d,aa[N],bb[N],cc[N],ab[N],ac[N],bc[N],saa,sbb,scc,sab,sac,sbc,eps=1e-8,ans;
inline bool cmp(double x)
{
    return fabs(x)<eps;
}
inline double solve(double a,double b,double c)
{
    if(cmp(a))
        return c;
    double x=-b/(2.0*a);
    return a*x*x+b*x+c;
}
int main()
{
    scanf("%d",&q);
    while(q--)
    {
        scanf("%d",&op);
        if(op==0)
        {
            scanf("%lf%lf%lf%lf",&X1,&Y1,&X2,&Y2);
            if(cmp(X1-X2))
                a=1,b=0,c=-X1;
            else
                a=(Y2-Y1)/(X2-X1),b=-1,c=Y1-a*X1;
            d=a*a+b*b;
            aa[++n]=a*a/d,bb[n]=b*b/d,cc[n]=c*c/d,ab[n]=a*b/d,ac[n]=a*c/d,bc[n]=b*c/d;
            saa+=aa[n],sbb+=bb[n],scc+=cc[n],sab+=ab[n],sac+=ac[n],sbc+=bc[n];
            m++;
        }
        if(op==1)
        {
            scanf("%d",&i);
            saa-=aa[i],sbb-=bb[i],scc-=cc[i],sab-=ab[i],sac-=ac[i],sbc-=bc[i];
            m--;
        }
        if(op==2)
        {
            if(!m)
            {
                puts("0.00");
                continue;
            }
            if(cmp(sbb))
                a=b=0;
            else
                a=-sab/sbb,b=-sbc/sbb;
            ans=solve(saa+2.0*a*sab+a*a*sbb,2.0*(b*sab+sac+a*b*sbb+a*sbc),b*b*sbb+2.0*b*sbc+scc);
            if(cmp(ans))
                ans=0;
            printf("%.2f\n",ans);
        }
    }
    return 0;
}

原文地址:https://www.cnblogs.com/lokiii/p/8453515.html

时间: 2024-10-11 16:17:05

bzoj 2876: [Noi2012]骑行川藏【拉格朗日乘数法+二分】的相关文章

bzoj 2876: [Noi2012]骑行川藏 拉格朗日数乘

2876: [Noi2012]骑行川藏 Time Limit: 20 Sec  Memory Limit: 128 MBSec  Special JudgeSubmit: 1033  Solved: 504[Submit][Status][Discuss] Description 蛋蛋非常热衷于挑战自我,今年暑假他准备沿川藏线骑着自行车从成都前往拉萨.川藏线的沿途有着非常美丽的风景,但在这一路上也有着很多的艰难险阻,路况变化多端,而蛋蛋的体力十分有限,因此在每天的骑行前设定好目的地.同时合理分配

BZOJ 2876 NOI2012 骑行川藏 二分+数学算法

题目大意:给定n段路,每段长度为si,如果在这段路上以vi的速度匀速行驶,那么消耗的体力为ki*(vi-v'i)^2*si,求在不超过体力上限情况下的最大速度 我去年买了个表- - 去网上百度了半天一元三次方程的求根公式才发现函数是递增的- - 百度百科写的什么NM破玩应- - 好像没讲明白- - MS只要知道拉格朗日乘数法就能差不多搞懂这道题了- - #include <cstdio> #include <cstring> #include <iostream> #i

【BZOJ2876】【NOI2012】骑行川藏 拉格朗日乘数、

题解: 不知道为什么用这个,但是这个确实能做. 呃,这里的v跟结果有单调关系,所以可以二分一下出解---- 拉格朗日方程粗浅理解(可能有误): 设一个λ来二分,并用此值算出自变量,然后check是否满足限制 如此得到正确的自变量,而后出解. 此题方程为下图式Ⅰ,而式Ⅱ是方程的v变量偏导函数,而Ⅲ则是经过小小的变形. (图片来自http://txhwind.blog.163.com/blog/static/203524179201313112815690/) 代码: #include <cstdi

NOI2012 骑行川藏 解题报告

当我还没看别人的解题报告时,我用了三分法做了40%的数据. 围观大神的解题报告,要通过100%的数据要用到拉格朗日乘数法求得最值. Wiki上的解释是这样的:Wikipedia Wiki的解释我自己看不太懂,下面这个视频可能让你能对拉格朗日乘数法有更好的认识:麻省理工学院<拉格朗日乘数法> 下面介绍一下拉格朗日乘数法是如何工作的: 问题:在g(x1, x2, x3, ..., xn) = c的约束条件下,求f(x1, x2, x3, ..., xn)的最值. 我们把问题具体化一下:令g(x,

bzoj2876 [NOI2012]骑行川藏(拉格朗日乘数法)

题目描述 蛋蛋非常热衷于挑战自我,今年暑假他准备沿川藏线骑着自行车从成都前往拉萨.川藏线的沿途有着非常美丽的风景,但在这一路上也有着很多的艰难险阻,路况变化多端,而蛋蛋的体力十分有限,因此在每天的骑行前设定好目的地.同时合理分配好自己的体力是一件非常重要的事情. 由于蛋蛋装备了一辆非常好的自行车,因此在骑行过程中可以认为他仅在克服风阻做功(不受自行车本身摩擦力以及自行车与地面的摩擦力影响).某一天他打算骑\(N\)段路,每一段内的路况可视为相同:对于第\(i\)段路,我们给出有关这段路况的3个参

[BZOJ2876] [NOI2012] 骑行川藏 - 数论 - 拉格朗日定理(拉格朗日乘子法) + 二分

[ 题外话 :          = =看了一眼题目就知道是求最值 然后就不会做了╮(╯▽╰)╭ 所以,数学渣就去学了一发拉格朗日乘数法 - -] 那么上正文TAT 由于公式太多,我就直接截图哈qwq 附代码: #include "stdio.h" #include "iostream" #define rep(f,a,b) for(f=a;f<=b;f++) using namespace std; const double eps=1e-12; const

bzoj2876 [Noi2012]骑行川藏 [二分+拉格朗日乘数法]

Description 蛋蛋非常热衷于挑战自我,今年暑假他准备沿川藏线骑着自行车从成都前往拉萨.川藏线的沿途有着非常美丽的风景,但在这一路上也有着很多的艰难险阻,路况变化多端,而蛋蛋的体力十分有限,因此在每天的骑行前设定好目的地.同时合理分配好自己的体力是一件非常重要的事情. 由于蛋蛋装备了一辆非常好的自行车,因此在骑行过程中可以认为他仅在克服风阻做功(不受自行车本身摩擦力以及自行车与地面的摩擦力影响).某一天他打算骑N段路,每一段内的路况可视为相同:对于第i段路,我们给出有关这段路况的3个参数

bzoj2876 [Noi2012]骑行川藏

Description 蛋蛋非常热衷于挑战自我,今年暑假他准备沿川藏线骑着自行车从成都前往拉萨.川藏线的沿途有着非常美丽的风景,但在这一路上也有着很多的艰难险阻,路况变化多端,而蛋蛋的体力十分有限,因此在每天的骑行前设定好目的地.同时合理分配好自己的体力是一件非常重要的事情. 由于蛋蛋装备了一辆非常好的自行车,因此在骑行过程中可以认为他仅在克服风阻做功(不受自行车本身摩擦力以及自行车与地面的摩擦力影响).某一天他打算骑 N段路,每一段内的路况可视为相同:对于第i段路,我们给出有关这段路况的3个参

NOI2012 骑行川藏

http://www.lydsy.com/JudgeOnline/problem.php?id=2876 表示完全不会...... 还是跪拜大神吧 http://www.cnblogs.com/GerynOhenz/p/4698451.html #include<cstdio> #include<cstdlib> #include<iostream> #include<fstream> #include<algorithm> #include&l