题意:对于MS Inc来说,每个月如果盈利则必盈利sur,如果亏空则必亏空def(这个公司很怪)。它每五个月进行一次统计,共统计八次(1-5月一次,2-6月一次...)。统计的结果是这八次都亏空。判断MS Inc全年否能盈利,如果能则求出最大的盈利。如果不能则输出"Deficit"。
思路:贪心,符合最优子结构性质。5个月统计一次都亏空,那么有5种情况:
1、若SSSSD亏空,那么全年可能最大盈利情况为: SSSSDSSSSDSS
2、若SSSDD亏空,那么全年可能最大盈利情况为:SSSDDSSSDDSS
3、若SSDDD亏空,那么全年可能最大盈利情况为: SSDDDSSDDDSS
4、若SDDDD亏空,那么全年可能最大盈利情况为: SDDDDSDDDDSD
5、若DDDDD亏空,那么全年可能最大盈利情况为: DDDDDDDDDDDD
代码如下:
#include <iostream>
using namespace std;
int main()
{
int s,d,ans;
while (scanf("%d%d",&s,&d)!=EOF)
{
if(4*s<d)
ans=10*s-2*d;
else if(3*s<2*d)
ans=8*s-4*d;
else if(2*s<3*d)
ans=6*s-6*d;
else if(s<4*d)
ans=3*s-9*d;
else
ans=-12*d;
if(ans>0)
printf("%d\n",ans);
else
printf("Deficit\n");
}
return 0;
}