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 }