BZOJ 2876 骑行川藏

http://www.lydsy.com/JudgeOnline/problem.php?id=2876

拉格朗日乘数法:f‘+入g‘=0,f为函数的导数,g为限制条件的导数。

思路:E=Σki*si*(vi-vi‘)^2,贪心可知,当E=Eu时,才能得到最优解。

我们假设函数f=Σsi/vi,限制g=Σki*si*(vi-vi‘)^2=E

根据拉格朗日乘数法,f‘+入g‘=0,

g‘=2*ki*si*(vi-vi‘)

f‘=-si/(vi^2)

可得-si/(vi^2)+2*入*ki*si*(vi-vi‘)=0

即2*入*ki*(vi^2)*(vi-vi‘)=1

由于入与vi负相关,且vi与E正相关,因此入与E负相关,因此满足单调,二分入的值,判断解是否等于E

2*入*ki*(vi^2)*(vi-vi‘)-1=0中,(vi^2)*(vi-vi‘)关于vi单调递增(vi>0),也可以通过二分来找方程的根。

 1 #include<algorithm>
 2 #include<cstdio>
 3 #include<cmath>
 4 #include<cstring>
 5 #include<iostream>
 6 const double eps=1e-12;
 7 const double inf=1e9;
 8 double ans[10005],k[10005],v[20005],s[20005],E;
 9 int n;
10 double calc(int x,double Mid){
11     double l=std::max(0.0,v[x]),r=inf;
12     while (r-l>eps){
13         double mid=(l+r)/2;
14         if (mid*mid*2*Mid*k[x]*(mid-v[x])-1>0) r=mid;
15         else l=mid;
16     }
17     return l;
18 }
19 double sqr(double x){
20     return x*x;
21 }
22 double work(double mid){
23     for (int i=1;i<=n;i++)
24      ans[i]=calc(i,mid);
25     double res=0;
26     for (int i=1;i<=n;i++)
27       res+=s[i]*k[i]*(sqr(v[i]-ans[i]));
28     return res;
29 }
30 int main(){
31     scanf("%d",&n);scanf("%lf",&E);
32     for (int i=1;i<=n;i++){
33         scanf("%lf%lf%lf",&s[i],&k[i],&v[i]);
34     }
35     double l=0,r=1e9;
36     while (r-l>eps){
37         double mid=(l+r)/2;
38         if (work(mid)>E) l=mid;
39         else r=mid;
40     }
41     double Ans=0;
42     for (int i=1;i<=n;i++)
43      Ans+=s[i]/ans[i];
44     printf("%.8f\n",Ans);
45 }
时间: 2024-11-05 23:27:40

BZOJ 2876 骑行川藏的相关文章

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

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

高等数学(拉格朗日乘子法):NOI 2012 骑行川藏

[NOI2012] 骑行川藏 输入文件:bicycling.in   输出文件:bicycling.out   评测插件 时间限制:1 s   内存限制:128 MB NOI2012 Day1 Description 蛋蛋非常热衷于挑战自我,今年暑假他准备沿川藏线骑着自行车从成都前往拉萨.川藏线的沿途有着非常美丽的风景,但在这一路上也有着很多的艰难险阻,路况变化多端,而蛋蛋的体力十分有限,因此在每天的骑行前设定好目的地.同时合理分配好自己的体力是一件非常重要的事情. 由于蛋蛋装备了一辆非常好的自

NOI2012 骑行川藏 解题报告

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

bzoj2876 [Noi2012]骑行川藏

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

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

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

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

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

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

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

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

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