POJ 1006 Biorhythms - 数学逻辑

本文解析了POJ1006Biorhythms题目,介绍了使用简单数学运算找到三个人体节律峰值再次同步所需的天数的方法,并提供了完整的C++代码实现。

POJ 1006 Biorhythms

题意:三个正整数的最小公约数相关。难度:1星。

根据相关逻辑关系直接计算,也不算复杂。注意,在current day就是next triple peak day时,答案应为一个周期(21252);next triple peak day有可能小于current day,此时答案应在下一个周期内(即再加21252)。

讨论区中有同学用“中国剩余定理”解决。

题解代码:

/*
 *	POJ 1006 Biorhythms
 *		简单数学运算:
 *
 *	说是可以用“中国剩余定理”;
 *
 */
#include <iostream>

using namespace std;

int main()
{
	int phyPeakDay, emoPeakDay, intPeakDay, currentDay, triPeakDay;
	int i, n = 1;

	while (cin >> phyPeakDay >> emoPeakDay >> intPeakDay >> currentDay && -1 != phyPeakDay)
	{
		phyPeakDay %= 23;
		emoPeakDay %= 28;
		intPeakDay %= 33;

		for (i = 0; ; i++)
		{
			triPeakDay = phyPeakDay + 23 * i;
			if (triPeakDay % 28 == emoPeakDay)
			{
				if (triPeakDay % 33 == intPeakDay)
				{
					break;
				}
			}
		}//for (i = 0; ; i++)

		cout << "Case " << n++ << ": the next triple peak occurs in " 
			<< (triPeakDay > currentDay ? triPeakDay - currentDay : triPeakDay - currentDay + 21252)
			<< " days.\n";
	}

	return 0;
}

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值