1434:相亲的胖胖

这篇博客探讨了一道有趣的数学问题,涉及到相亲活动中选择数字与最大公因数的关联。胖胖在交友平台上选择了数字m,实际上触发了与m互质的相亲对象约会的规则。通过欧拉函数,我们可以计算出1到m之间与m互质的数字数量,即胖胖的约会对象数量。博客详细介绍了如何使用欧拉函数来解决此类问题,并提供了样例输入和输出,帮助读者理解算法的实现过程。

1434:相亲的胖胖

描述
胖胖有一次参加了一个由某交友平台(Github)举办的相亲活动,一共有m个相亲对象,编号分别为1、2、…、m。举办方让胖胖选择1至m中的某个整数,胖胖以为是挑选心仪的对象编号,于是为了省时间草率选择了数字m,然而举办方的规则是:根据选择的数字,凡是编号和该数字(也就是m)的最大公因数等于1的相亲对象都会分别跟胖胖约会。问胖胖的约会对象共有多少个?

输入
多组案例。一个正整数n,表示案例的数量。(n<=100)
每组案例由一个正整数m组成。(1<=m<=10亿)

输出
针对每组案例,输出一个整数, 表示跟胖胖约会的对象数量。
每组案例输出完都要换行。

样例输入
2
16
12

样例输出
8
4

HINT
第1组案例中,与16的最大公因数为1的编号是:1、3、5、7、9、11、13、15
第2组案例中,与12的最大公因数为1的编号是:1、5、7、11

#include<iostream>
using namespace std;
int main()
{
	int n;
	cin >> n;
	while (n--)
	{
		//求1~m之间与m互质的数字数量
		int m, a, b = 2;
		//b表示下一个尝试的质因数
		cin >> m;
		a = m;
		//a表示原始的m值
		while (a > 1)
		{
			if (a % b == 0)
			{
				m = m - m / b;
				//m = m * (1-1/b) = m-m/b 欧拉公式
				while (a % b == 0)
				{
					a = a / b;
				}
				//除去多余因子
			}
			b++;
			if (b * b > a)
			{
				b = a;
			}
		}
		cout << m << endl;
	}
	return 0;
}
// 欧拉函数的应用
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值