栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

莫比乌斯函数---C++

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

莫比乌斯函数---C++

【问题描述】
莫比乌斯函数,数论函数,由德国数学家和天文学家莫比乌斯(Mobius,1790-1868)提出。梅滕斯(Mertens)首先使用μ(n)作为莫比乌斯函数的记号。而据说,高斯(Gauss)比莫比乌斯早三十年就曾考虑过这个函数。莫比乌斯函数在数论中有着广泛的应用。
莫比乌斯函数完整定义的通俗表达:
1)莫比乌斯函数μ(n)的定义域是N
2)μ(1)=1
3)当n存在平方因子时,μ(n)=0
4)当n是素数或奇数个不同素数之积时,μ(n)=-1
5)当n是偶数个不同素数之积时,μ(n)=1

例如:
μ(8),μ(12),μ(18)都为08的因数为1,2,4,8;其中4=2*2故μ(8)=0
μ(2),μ(3),μ(30)都为-1
μ(1),μ(6),μ(10)都为1
给出一个数n,计算μ(n)。
【输入形式】
输入一行一个整数n
【输出形式】
输出μ(n)
【样例输入】
12
【样例输出】
0

#include 
#include 
#include 
using namespace std;
int mobius(int n);
int main()
{
    int n;
    scanf("%d",&n);
    mobius(n);
    return 0;
}
int mobius(int n)
{
    if(n==1)//1就是1
    {
        return 1;
    }
    else
    {
        int res=-1;//开始为奇数
        for(int i=2; i<=sqrt(n); i++)//简便数的运算,判断素数常用,取一半数就行
        {
            //能进去if里面的肯定不是素数,若该数就是一个素数直接输出-1就行了
            if(n%i==0 && n/i%i==0)//非素数,并且还有平方因子,既然/i%i为0,也就是i*i就是那个完全平方数
            {
                return 0;
            }
            else if(n%i==0)//非素数
            {
                res*=-1;//res负责判断素数为奇数还是偶数,来一次变一次,偶数为1,奇数为-1
                n/=i;
            }
        }
        printf("%d",res);//当res一次都没进入if里面,说明该数就是个素数,单个素数就是-1
        return 0;
    }
}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/353083.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号