POJ1010 Stamps

题目来源:http://poj.org/problem?id=1010

题目大意:

  某邮局要设计新的邮资管理软件,依据顾客的需要和现有的面值给顾客分派邮票。

  该邮局有很多顾客是集邮爱好者。这些人希望得到最多种类不同的邮票。该邮局会发行同一面值的不同邮票。邮票的面值最大为25.

  为节约成本,邮局希望尽可能少的重复邮票。(他们希望发行尽可能多的不同种类的邮票)。而且,邮局对一个客户一次最多卖4张邮票。

输入:程序的输入是多组两行的数据。以EOF结束。第一行是现有的邮票的面值,以0结束。第二行是一系列的客户需求。

输出:对于每一个客户,输出“最好”的邮票组合(邮票种类数最多)。面值和恰好为客户的需要,邮票张数最大为4。如果找不到这样的组合,输出“none”。如果有多个“最好”组合,选择邮票总数最少的一组,如果仍然相等,邮票面值中单张价格最高的最优,若仍然相等,输出“tie”。具体格式见Example Output.


Sample Input

1 2 3 0  ; three different stamp types
7 4 0    ; two customers
1 1 0    ; a new set of stamps (two of the same type)
6 2 3 0   ; three customers

Sample Output

7 (3): 1 1 2 3 
4 (2): 1 3 
6 ---- none
2 (2): 1 1
3 (2): tie

因为一次最多四张邮票,于是用了最傻的方法,找出所有可行的组合再按规则找最优解。另外测试数据中邮票面值实际是按升序输入的,若不按升序输入,则预先在程序中进行排序即可。拙劣代码奉上。

  1 //////////////////////////////////////////////////////////////////////////
  2 //        POJ1010 Stamps
  3 //        Memory: 5356K        Time: 32MS
  4 //        Language: C++        Result: Accepted
  5 //////////////////////////////////////////////////////////////////////////
  6 
  7 #include <iostream>
  8 #include <vector>
  9 
 10 using namespace std;
 11 
 12 class Solution {
 13 public:
 14     int stamps[4];
 15     int types;
 16     int count;
 17     int maxValue;
 18 };
 19 
 20 int types[100];
 21 int typeCount;
 22 int customer;
 23 int customerCount;
 24 vector<Solution> sVector;
 25 bool isTie;
 26 
 27 int getTypes(int i0, int i1, int i2 = -1, int i3 = -1) {
 28     if (i3 == -1 && i2 == -1) {
 29         if (i0 == i1) {
 30             return 1;
 31         } else {
 32             return 2;
 33         }
 34     } else if (i3 == -1) {
 35         if (i0 == i1 && i1 == i2) {
 36             return 1;
 37         } else if (i1 == i2 || i0 == i1 || i0 == i2) {
 38             return 2;
 39         } else {
 40             return 3;
 41         }
 42     } else if(i0 == i1 && i1 == i2 && i2 == i3) {
 43         return 1;
 44     } else if (i0 != i1 && i0 != i2 && i0 != i3 && i1 != i2 && i1 != i3 && i2 != i3) {
 45         return 4;    
 46     } else if (i0 == i1 && i1 != i2 && i2 != i3 && i3 != i1 
 47         || i0 == i2 && i0 != i1 && i0 != i3 && i1 != i3
 48         || i0 == i3 && i0 != i1 && i0 != i2 && i1 != i2
 49         || i1 == i2 && i0 != i1 && i2 != i3 && i0 != i3
 50         || i1 == i3 && i0 != i1 && i1 != i2 && i0 != i2
 51         || i2 == i3 && i2 != i0 && i2 != i1 && i0 != i1 ) {
 52             return 3;
 53     } else {
 54         return 2;
 55     }
 56 }
 57 
 58 int findBestSolution() {
 59     int bestSolution = 0;
 60     if (sVector.size() == 1) return 0;
 61     for (int i = 1; i < sVector.size(); i++) {
 62         if (sVector[i].types > sVector[bestSolution].types) {
 63             isTie = false;
 64             bestSolution = i;
 65         } else if (sVector[i].types == sVector[bestSolution].types) {
 66             if (sVector[i].count < sVector[bestSolution].count) {
 67                 isTie = false;
 68                 bestSolution = i;
 69             } else if (sVector[i].count == sVector[bestSolution].count) {
 70                 if (sVector[i].maxValue > sVector[bestSolution].maxValue) {
 71                     isTie = false;
 72                     bestSolution = i;
 73                 } else if (sVector[i].maxValue == sVector[bestSolution].maxValue) {
 74                     isTie = true;
 75                 }
 76             }
 77         }
 78     }
 79     return bestSolution;
 80 }
 81 
 82 void Output(int sindex) {
 83     Solution sulotion = sVector[sindex];
 84     cout << " (" << sulotion.types << "):";
 85     for(int i = 0; i < sulotion.count; i++) {
 86         cout << " " << sulotion.stamps[i]; 
 87     }
 88     cout << endl;
 89 }
 90 int main(void) {
 91     while(cin >> types[0]) {
 92         while (types[typeCount] != 0) {
 93             cin >> types[++typeCount];
 94         }
 95         while (cin >> customer) {
 96             if (customer == 0) {
 97                 break;
 98             }
 99             if (types[0] * 1 > customer) {
100                 cout << customer << " ---- none" << endl;
101                 continue;
102             }
103             if (types[typeCount - 1] * 4 < customer) {
104                 cout << customer << " ---- none" << endl;
105                 continue;
106             }
107             for (int i0 = 0; i0 < typeCount; i0++) {
108                 if(types[i0] == customer) {
109                     Solution solution;
110                     solution.stamps[0] = types[i0];
111                     solution.stamps[1] = 0;
112                     solution.stamps[2] = 0;
113                     solution.stamps[3] = 0;
114                     solution.maxValue = types[i0];
115                     solution.count = 1;
116                     solution.types = 1;
117                     sVector.push_back(solution);
118                     continue;
119                 } else if (types[i0] < customer){
120                     for (int i1 = i0; i1 < typeCount; i1++) {
121                         if(types[i0] + types[i1] == customer) {
122                             Solution solution;
123                             solution.stamps[0] = types[i0];
124                             solution.stamps[1] = types[i1];
125                             solution.stamps[2] = 0;
126                             solution.stamps[3] = 0;
127                             solution.maxValue = types[i1];
128                             solution.count = 2;
129                             solution.types = getTypes(i0, i1);
130                             sVector.push_back(solution);
131                             continue;
132                         } else if (types[i0] + types[i1] < customer) {
133                             for(int i2 = i1; i2 < typeCount; i2++) {
134                                 int sum = types[i0] + types[i1] + types[i2];
135                                 if(sum == customer) {
136                                     Solution solution;
137                                     solution.stamps[0] = types[i0];
138                                     solution.stamps[1] = types[i1];
139                                     solution.stamps[2] = types[i2];
140                                     solution.stamps[3] = 0;
141                                     solution.maxValue = types[i2];
142                                     solution.count = 3;
143                                     solution.types = getTypes(i0, i1, i2);
144                                     sVector.push_back(solution);
145                                 } else if (sum < customer){
146                                     for(int i3 = i2; i3 < typeCount; i3++) {
147                                         int sum = types[i0] + types[i1] + types[i2] + types[i3];
148                                         if(sum == customer) {
149                                             Solution solution;
150                                             solution.stamps[0] = types[i0];
151                                             solution.stamps[1] = types[i1];
152                                             solution.stamps[2] = types[i2];
153                                             solution.stamps[3] = types[i3];
154                                             solution.maxValue = types[i3];
155                                             solution.count = 4;
156                                             solution.types = getTypes(i0, i1, i2, i3);
157                                             sVector.push_back(solution);
158                                         } else if (sum > customer) {
159                                             break;
160                                         }
161                                     }
162                                 } else {
163                                     break;
164                                 }
165                             }
166                         } else {
167                             break;
168                         }
169                     }
170                 }  else {
171                     break;
172                 }
173             }
174             if (sVector.size() == 0) {
175                 cout << customer << " ---- none" << endl;
176                 continue;
177             }
178             int bestSolution = findBestSolution();
179             if (isTie) {
180                 cout << customer << " (" << sVector[bestSolution].types << "): tie" << endl;
181             } else {
182                 cout << customer;
183                 Output(bestSolution);
184             }
185             sVector.clear();
186             isTie = false;
187         }
188         customerCount = 0;
189         typeCount = 0;
190         sVector.clear();    
191     }
192     system("pause");
193     return 0;
194 }
View Code
原文地址:https://www.cnblogs.com/dengeven/p/3226773.html