+题目描述
原理:
明明家从 1 号站点出发,开车去旅游,一共要经过 n 个站点,依次为 2 、3 …… n 。
由于明明带上了心爱的小猫,在每个站点都要为小猫提供一条鱼用做美餐(包括 1 号站点)。
除了 1 号站点只能吃 1 号站点买的鱼,其他站点既可以吃当地买的鱼,也可吃之前经过的站点买了存入车载冰箱中的鱼。
但车载冰箱消耗的电能来自汽油,所以每条鱼用冰箱保存到下一站的费用与各个站点的汽油价格有关。
为使问题简化,我们约定:
(1)车从某站开出时油箱中都是此站点刚加的汽油。
(2)车载冰箱能容纳一路上需要的所有鱼。
即:每条鱼的费用既包括购买时的费用,也包括用冰箱保存鱼的费用。
编程实现:
为了降低小猫吃鱼的总代价,明明预先上网查到了这 n 个站点的鱼价和汽油价格。并据此算出每个站点买一条鱼的费用以及从该站点到下一站用冰箱保存一条鱼的费用。你能帮明明算出这一路上小猫吃鱼的最小总费用吗?
输入
第一行:站点数 n,1<n<100。
接下来的 n 行,每行两个以空格分隔的正整数,表示:这一站买一条鱼的费用,以及从这一站把每条鱼保存到下一站的费用,两个费用均为小于10000的正整数。
输出
最小总费用,是一个正整数。
样例
输入
5
6 3
7 1
3 2
8 3
9 5
输出
29
题意+思路
题目有很多废话,简单来看就是酱的意思:拿现在的鱼费跟比较上一次的车费+鱼费比较,哪个小就用哪个。
用代码来表示就是酱紫的:
ans=ans+mi;
mi=mi+b[i];
其中ans表示最小总费用,mi表示这一站买一条鱼的最小费用+车费。
Q:那为啥不用让现在的鱼费也加上车费捏?
A:很简单啦,因为是在这一站买的,木有开车,所以不用算这次的车费鸭~
没质量的问题
代码
ok,思路懂了,看代码:
#include <bits/stdc++.h>
using namespace std;
//a[]:本站买1条鱼的费用
//b[]:从本站到下一站的车费
//mi和ans解释过了
int n,a[110],b[110],mi=INT_MAX,ans;
int main(){
cin>>n;
for(int i=0;i<n;i++){
cin>>a[i]>>b[i];
}
for(int i=0;i<n;i++){
if(a[i]<mi){//如果遇到了更小的鱼费
mi=a[i];//替换
}
ans=ans+mi;//把本站用的所有费用加起来,当然肯定是最小的了
mi=mi+b[i];//车费也是要算滴~
}
cout<<ans;
return 0;
}
给个赞吧球球惹