XYNUOJ 1234: 出租车费

1234: 出租车费

时间限制: 1 Sec  内存限制: 32 MB
提交: 137  解决: 70
您该题的状态:已完成
[提交][状态][讨论版]

题目描述

某市出租车计价规则如下:起步4公里10元,即使你的行程没超过4公里;接下来的4公里,每公里2元;之后每公里2.4元。行程的最后一段即使不到1公里,也当作1公里计费。
一个乘客可以根据行程公里数合理安排坐车方式来使自己的打车费最小。
例如,整个行程为16公里,乘客应该将行程分成长度相同的两部分,每部分花费18元,总共花费36元。如果坐出租车一次走完全程要花费37.2元。
现在给你整个行程的公里数,请你计算坐出租车的最小花费。

输入

输入包含多组测试数据。每组输入一个正整数n(n<10000000),表示整个行程的公里数。
当n=0时,输入结束。

输出

对于每组输入,输出最小花费。如果需要的话,保留一位小数。

样例输入

3
9
16
0

样例输出

10
20.4
36
#include<cstdio>
int main()
{
	int n;
	while(~scanf("%d",&n)&&n)
	{
		double w=0.0;//花费的价钱可以是小说,因此价钱用double定义
		if(n<=4)//当路程<=4公里时,都是十元钱
			w=10;
		if(n>4&&n<=8)//如果路程>4公里,<=8公里,则每公里2元钱
			w=10+(n-4)*2;
		if(n>8)
		{
			while(n>8)//当路程>8公里时,将总路程分成多个8公里,因为8公里最便宜
			{
				w=w+18;
				n=n-8;
			}//当n<=8公里时,退出循环
			if(n<=4)
				w=w+n*2.4;
			else
				w=w+10+(n-4)*2;
		}
		if(w-(int)w!=0)//当有小数存在时,应该输出后一位小数
			printf("%.1f\n",w);
		else//否则输出整数
			printf("%d\n",(int)w);
	}
	return 0;
}

猜你喜欢

转载自blog.csdn.net/yxy602843889/article/details/81275519