题意:有一个公司由于某个病毒使公司赢亏数据丢失,但该公司每月的 赢亏是一个定数,要么一个月赢利s,要么一月亏d。现在ACM只知道该公司每五个月有一个赢亏报表,而且每次报表赢利情况都为亏。在一年中这样的报表总共有8次(1到5,2到6,…,8到12),现在要编一个程序确定当赢s和亏d给出,并满足每张报表为亏的情况下,全年公司最高可赢利多少,若存在,则输出多多额,若不存在,输出"Deficit"。
分析:读懂题意后,大概知道这是一个贪心。初始时,将每个月份都设为盈利,由于区间后部和下一个区间重合,所以把亏损的放在尽可能后面,与下一个区间共用。(不过似乎不用贪心,分情况讨论,把12个月的盈亏情况直接写出来就行。)
代码:
#include <iostream>
#include <fstream>
using namespace std;
int month[13];
int main()
{
//fstream cin("test.txt");
int s, d;
while (cin >> s >> d)
{
for (int i = 1; i <= 12; i++)
month[i] = s;
for (int i = 1; i <= 8; i++)
{
int total = 0;
for (int j = i; j <= i + 4; j++)
total += month[j];
if (total > 0)
{
for (int j = i + 4; j >= i; j--)
{
if (month[j] > 0)
{
month[j] = -d;
total -= (s + d);
if (total < 0)
break;
}
}
}
}
int ans = 0;
for (int i = 1; i <= 12; i++)
ans += month[i];
if (ans > 0)
cout << ans << endl;
else
cout << "Deficit" << endl;
}
//system("pause");
return 0;
}