51Nod-1240-莫比乌斯函数

51Nod-1240-莫比乌斯函数

                    1240 莫比乌斯函数  

莫比乌斯函数,由德国数学家和天文学家莫比乌斯提出。梅滕斯(Mertens)首先使用μ(n)(miu(n))作为莫比乌斯函数的记号。(据说,高斯(Gauss)比莫比乌斯早三十年就曾考虑过这个函数)。
具体定义如下:
如果一个数包含平方因子,那么miu(n) = 0。例如:miu(4), miu(12), miu(18) = 0。
如果一个数不包含平方因子,并且有k个不同的质因子,那么miu(n) = (-1)^k。例如:miu(2), miu(3), miu(30) = -1,miu(1), miu(6), miu(10) = 1。
给出一个数n, 计算miu(n)。
Input
输入包括一个数n,(2 <= n <= 10^9)
Output
输出miu(n)。
Input示例
5
Output示例
-1

解题方法

题意为:
1.输出为0,即当n的因子中含有平方因子;
2.输出为-1,即当n的因子不含有平方因子,且质因子个数为奇数个;
3.输出为1,即当n的因子不含有平方因子,且质因子个数为偶数个。

解法:
任意一个数都能由质因子来合成。
遍历n的所有质因子,如果同一个因子出现两次,即含有平方因子,则符合第一种情况,输出为0;
否则,统计质因子出现的个数,然后判断奇偶。


解题代码

def miu(n):
    num = 0

    # 开始用质因子分解n
    for i in range(2, n+1):
        cnt = 0
        if i*i > n: break

        if n%i == 0:
            num += 1       # 统计不同质因子个数
            while n%i == 0:
                n //= i    # 每次分解成功都更新n
                cnt += 1   # 统计相同质因子个数
            if cnt >= 2:
                return 0

    return -1 if num%2 == 0 else 1  # 判断奇偶

while True:
    try:
        N = int(input())
        print(miu(N))
    except EOFError:
        break
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值