Codeup贪心:出租车费

题目描述

某市出租车计价规则如下:起步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<bits/stdc++.h>
using namespace std;
int main(){
	int n,temp;
	while(scanf("%d",&n),n!=0){
		double sum=0;//一次循环之后,一定要记得恢复sum为0,否则会继续累加sum
		if(n<=4) sum=10;
		else if(n<=8){
			sum=10+(n-4)*2;
		} 
		else if(n>=8){
			while(n>=8){
				sum+=18;
				n-=8;
			}
			if(n<=4) {sum+=n*2.4;}
			else {sum+=10+(n-4)*2; }
			
		}
		if(sum==(int)sum)
			printf("%d\n",(int)sum);
		else printf("%.1f\n",sum);
	}
	return 0;
} 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
汽车加油问题是一个经典的贪心算法问题。假设有一辆汽车要从起点出发到达终点,途中需要经过n个加油站。已知汽车在满油的情况下最多可以行驶d距离,每个加油站离起点的距离为ai,到达该加油站需要加bi升油。请问汽车从起点出发是否能到达终点,如果能,最少需要加多少升油? 解题思路如下: 1.定义一个变量cur表示当前汽车的油量,初始为0,定义一个变量ans表示加油的总量,初始为0。 2.从起点开始遍历每个加油站,假设当前到达第i个加油站。 3.判断当前汽车是否能到达下一个加油站,如果能,则不需要加油,直接到达下一个加油站。如果不能,则需要在当前加油站加油,加油量为到达下一个加油站所需的最少油量,即bi。 4.将ans加上加油量bi,cur减去加油量bi,表示汽车在当前加油站加了bi升油后,剩余油量为cur。 5.重复步骤2-4,直到到达终点。 6.如果汽车能到达终点,则返回ans,否则返回-1表示无法到达终点。 代码实现如下(假设ai是一个升序的数组): ```python def min_refuel_stops(target, startFuel, stations): n = len(stations) pq = [] # 定义一个优先队列,存储每个加油站能提供的油量(负数,因为要从大到小取) ans = 0 cur = startFuel prev = 0 # 表示上一个加油站的位置 for i in range(n): distance = stations[i][0] - prev # 表示到达当前加油站需要的距离 while cur < distance: # 如果当前油量到不了下一个加油站 if not pq: # 如果优先队列为空,表示无法到达终点 return -1 cur += -heapq.heappop(pq) # 从优先队列中取出能提供的最大油量,加到当前油量中 ans += 1 # 加油次数加1 cur -= distance # 到达下一个加油站,当前油量减去到达该加油站需要的油量 prev = stations[i][0] # 更新上一个加油站的位置 heapq.heappush(pq, -stations[i][1]) # 将当前加油站能提供的油量加入优先队列 distance = target - prev # 到达终点需要的距离 while cur < distance: # 如果当前油量到不了终点 if not pq: # 如果优先队列为空,表示无法到达终点 return -1 cur += -heapq.heappop(pq) # 从优先队列中取出能提供的最大油量,加到当前油量中 ans += 1 # 加油次数加1 return ans ``` 这样,就可以用贪心算法解决汽车加油问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值