首页 > 技术文章 > UVa 11400 照明系统设计

zyb993963526 2017-02-03 10:25 原文

https://vjudge.net/problem/UVA-11400

题意:

有一个照明系统需要用到n种灯,每种灯的电压为V,电源费用K,每个灯泡费用为C,需要该灯的数量为L。注意到,电压相同的灯泡只需要共享一个对应的电源即可,还有电压低的灯泡可以被电压高的灯泡替代。为了节约成本,你将设计一种系统,使之最便宜。

思路:

这道题和我之前做的POJ 1260(具体也可以看一下这题) 基本上是一样的,首先是按电压排序,设sum[i]为前i种灯泡的总数量,d[i]为灯泡1~i的最小开销,则d[i]=min{d[j]+(sum[i]-sum[j])*c[i]+k[i])},表示前j个先用最优方案买,然后第j+1~i个都用第i号的电源。答案为d[n]。

 1 #include<iostream> 
 2 #include<algorithm>
 3 #include<cstring>
 4 using namespace std;
 5 
 6 const int maxn = 1000 + 10;
 7 
 8 int n;
 9 int d[maxn];
10 int sum[maxn];
11 
12 struct node
13 {
14     int v, k, c, l;
15 }a[maxn];
16 
17 bool cmp(node a, node b)
18 {
19     return a.v < b.v;
20 }
21 
22 
23 int main()
24 {
25     //freopen("D:\\txt.txt", "r", stdin);
26     while (cin >> n && n)
27     {
28         
29         for (int i = 1; i <= n; i++) 
30         {
31             cin >> a[i].v >> a[i].k >> a[i].c >> a[i].l;
32         }
33         sort(a + 1, a + n + 1, cmp);   
34 
35         sum[0] = 0;
36         for (int i = 1; i <= n; i++) {
37             sum[i] = sum[i - 1] + a[i].l;
38         }
39         d[0] = 0;
40         for (int i = 1; i <= n; i++) {
41             d[i] = d[i - 1] + a[i].c*a[i].l + a[i].k;    //未优化之前的购买方式
42             for (int j = 0; j < i; j++) {
43                 d[i] = min(d[i], d[j] + (sum[i] - sum[j]) * a[i].c + a[i].k);
44             }
45         }
46         cout << d[n] << endl;
47     }
48     return 0;
49 }

 

推荐阅读