7651:自来水供给

总时间限制: 

1000ms

内存限制: 

65536kB

描述

有n个村子,坐落在从县城出发的一条公路上。

现在要通过安装水管,从县城向各村供给自来水。水管有粗细两种,粗管可供给任意数量的村子,而细管只能供给一个村子。粗管每公里8000元,细管每公里2000元。

问如何搭配粗管和细管,使得费用最低?

输入

第一行:一个整数n。0 < n < 100。
第二行:n个整数,按与县城的距离从近到远给出各村与县城的距离,两个整数之间用单个空格隔开。距离单位为公里,不超过100。

输出

一个整数,即最低费用。

样例输入

10
30 5 2 4 2 3 2 2 2 5

样例输出

414000

#include <iostream>
 using namespace std;
 const int MAXINT = ~((unsigned int)0) >> 1;
 const int N = 100;
 int s[N+1], t[N+1];
 int main()
{
    int n, ans;
     cin >> n;
     s[0] = 0;
    t[0] = 0;
     for(int i=1; i<=n; i++) {
        cin >> s[i];
        s[i] += s[i - 1];
         t[i] = t[i - 1] + s[i];
    }
     ans = MAXINT;
    for(int i=1; i<=n; i++)     // 前粗后细 
        ans = min(ans, s[i] * 8000 + (t[n] - t[i] - (n - i) * s[i]) * 2000);
     cout << ans << endl;
     return 0;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值