UVA - 10050 - Hartals

http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=103&page=show_problem&problem=991


题意:

    输入N个工会的罢工周期,给定周期T,求该周期内有几天罢工;注意,周五周六休息不算罢工,一天同时多个罢工只计一个。

解题:

    原来用简单数组就可以统计出来,并不是求公约数or公倍数之类的。。。


抄抄更健康。。。


#include <iostream>
#include <stdio.h>
#include <vector>
using namespace std;

// #define LOCAL_TEST


int calc_lost(vector<int> vHartal, int nDays)
{
	vector<int> days;
	days.resize(nDays);
	for ( int i=0; i<nDays; i++ )
		days[i] = 0;

	for ( int i=0; i<nDays; i++ )
		if ( i%7 != 5 && i%7 != 6 )
		{
			for ( int k=0; k<vHartal.size(); k++ )
				if ( (i+1)%vHartal[k] == 0 )
				{
					days[i] = 1;
					break;
				}
		} // end if

	// count '1' in vector vHartal
	int nRes = 0;
	for ( int i=0; i<nDays; i++ )
		if ( days[i] == 1 )
			nRes++;
	return nRes;
}


int main()
{
#ifdef LOCAL_TEST
	freopen("f:\\in.txt", "r", stdin);
	freopen("f:\\out.txt", "w+", stdout);
#endif
	int nCases;
	int nDays;
	vector <int> vHartal;
	int nParty;

	cin >>nCases;

	while ( nCases-- )
	{
		cin >>nDays;

		cin >>nParty;
		vHartal.resize(nParty);

		for ( int i=0; i<nParty; i++ )
			cin >>vHartal[i];

		cout <<calc_lost(vHartal, nDays) <<'\n';
	} // end while

	return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值