[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 double inf=1e5;
const int N=10005;

void read(int &v){
    char ch=getchar(); while (ch<'0'||ch>'9') ch=getchar();
    while (ch<='9'&&ch>='0') { v=v*10+ch-'0'; ch=getchar();}
}

int n; double eu;
double s[N],k[N],vi[N];
double v[N],atime,lagra;

double speed(double y,int t,double &x){
    double bot=max(0.0,y),top=inf;
    while (x=(bot+top)/2,top-bot>eps){
        if (2*lagra*k[t]*x*x*(x-y)<=1) bot=x; else top=x;
    }
}

bool check(){
    int i; double esum=0.0;
    rep(i,1,n) {
        speed(vi[i],i,v[i]);
        esum+=k[i]*(v[i]-vi[i])*(v[i]-vi[i])*s[i];
    }
    return esum>=eu;
}

int main(){
    //freopen("bicycling.in","r",stdin);
    //freopen("bicycling.out","w",stdout);
    read(n); int i;
    scanf("%lf",&eu);
    rep(i,1,n) {
        scanf("%lf%lf%lf",s+i,k+i,vi+i);
    } double bot=0.0,top=inf;
    while (lagra=(bot+top)/2,top-bot>eps){
        if (check()) bot=lagra;
        else top=lagra;
    }
    rep(i,1,n) atime+=s[i]/v[i];
    printf("%.10lf\n",atime);
    return 0;
}
时间: 2024-12-15 02:53:20

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

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

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

bzoj2876 [Noi2012]骑行川藏

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

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

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

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 i

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

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

NOI2012 骑行川藏 解题报告

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

【bzoj2876】 Noi2012—骑行川藏

http://www.lydsy.com/JudgeOnline/status.php (题目链接) 题意 在满足约束条件$${\sum_{i=1}^ns_ik_i(v_i-v_i')^2=E}$$ 求$${min\sum_{i=1}^n\frac{s_i}{v_i}}$$ Solution 像这种形式的存在一个多元函数${g(v_1,v_2,v_3,······,v_n)=E}$的约束,求解多元函数${f(v_1,v_2,v_3,······,v_n)}$的最值,我们使用拉格朗日乘子法. 在解

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

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

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