B题
题目:https://vjudge.net/contest/436484#problem/B
两个序列a和b的值分别都为0,1,2。现在对于定义的c序列要最大,就使2和1配,0和2配。目的增加2的出现减少-2
所以我们可以有(2,1),(0,2),(2,2)
#include<stdio.h> int main() { int t,x1,y1,z1,x2,y2,z2; scanf("%d",&t); while(t--) { int sum=0; scanf("%d %d %d",&x1,&y1,&z1); scanf("%d %d %d",&x2,&y2,&z2); if(z1>=y2)//判断2和1的数量,使将+2加完 { sum+=2*y2; z1-=y2; if(z1+x1>=z2)//如果a中剩下的2和0比b中的2多,则无-2,此时sum最大 { printf("%d\n",sum); } else { z2=z2-x1-z1; y1-=x1; sum-=2*z2; printf("%d\n",sum); } } else if(z1<y2) { sum=2*z1; y2-=z1; if(x1>=z2) { x1-=z2; printf("%d\n",sum); } else { z2-=x1; sum-=z2*2; printf("%d\n",sum); } } } return 0; }
浙公网安备 33010602011771号