POJ2586 Y2K Accounting Bug(贪心)

题意:有一个公司由于某个病毒使公司赢亏数据丢失,但该公司每月的 赢亏是一个定数,要么一个月赢利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;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值