SDJZUOJ 1128 出租车费 题目链接:http://sdjzu.acmclub.com/index.php?app=problem_title&id=147&problem_id=1128
数学水(被初中数学虐死了)
题目大意:中文不解释。
题目分析:通过分析平均车费,可得8公里处为极小值点,只要路程超过16公里,就可分出一段8公里的路程单独来跑。那么在16公里内呢,
由上图,16内可分为四段0~4、4~8、8~12、12~16,但是,12并不是一个真正的分割点,根据16的平均费用,向左做辅助线,得到交点x值为6.153……,将其乘2得到12的替代点。
code:
#include<stdio.h>
const double a=32*1./5.2;
int main()
{
int i,j;
double n,ans;
while(scanf("%lf",&n)!=EOF&&n)
{
ans=0;
while(n>=16)
{
ans+=18;
n-=8;
}
if(n<=4)ans+=10;
else if(n<=8)ans+=10+2*(n-4);
else if(n<=2*a)ans+=18+2.4*(n-8);
else ans+=20+2*(n-8);//
if(ans-(int)ans<=0.0001)printf("%.0f\n",ans);
else printf("%.1f\n",ans);
}
}
PS:a是算出来的,注释处错了几次,初中数学,没啥水准,被坑了……
题目分析:通过分析平均车费,可得8公里处为极小值点,只要路程超过16公里,就可分出一段8公里的路程单独来跑。那么在16公里内呢,