DES:给出三种材料A,B,C每种的个数。然后组合AB,BC,AC的利润。问能获得的最大利润是多少。
开始一点思路都没有。然后发现可以枚举其中两种的个数。那么最后一种就确定了。还是感觉很机智。
data:image/s3,"s3://crabby-images/6da44/6da44a3c422e49abcf1dae786223d28e774e2de6" alt=""
#include<stdio.h> #include<iostream> #include<string.h> using namespace std; int main() { int t; int ab, bc, ac; int a, b, c; scanf("%d ", &t); while(t--) { scanf("%d%d%d%d%d%d", &a, &b, &c, &ab, &bc, &ac); int ans = 0; //cout << "ab bc ac "; for (int i=0; i<=a; ++i) //ab { for (int j=0; j<=b-i; ++j) //bc { int tt; if (a-i > c-j) tt = c-j; //ac else tt = a-i; if (tt < 0) continue; //cout << tt << "== "; if (i+j>b || i+tt>a || j+tt>c) continue; int ttt = ab*i + j*bc + tt*ac; //cout << i << "==" << j << "==" << tt << endl; //cout << ttt << endl; if (ans < ttt) ans = ttt; } } printf("%d ", ans); } return 0; }