数学知识(一)

一、数论

1.1质数

**定义:**在所有大于1的自然数,如果只包含1和本身这两个约数,就被称为质数(素数).

**质数的判断:**试除法

cpp 复制代码
bool is_prime(int n)
{
    if(n < 2) return false;
    for(int i = 2;i <= n / i;i ++)
    {
        if(n % i == 0)
            return false;
    }
    return true;
}

分解质因数

基本思路:从小到大枚举n的所有约数。

cpp 复制代码
void divide(int n)
{
    for(int i = 2;i <= n;i ++)
    {
        if(n % i == 0)
        {
            int s = 0;
            while(n % i == 0)
            {
                n /= i;
                s ++;
            }
            printf("%d %d\n",i,s)
        }
    }
}

埃氏筛法

cpp 复制代码
#include<iostream>
#include<algorithm>

using namespace std;

int primes[N],cnt;
bool st[N];

void get_prime(int n)
{
    for(int i = 2;i <= n;i ++)
    {
        if(!st[i])
        {
            primes[cnt ++] = n;
            for(int j = i + i;j <= n;j += i) st[j] = true;
        }
    }
}

线性筛法

保证了每个数都是被他的最小质因子所筛掉

cpp 复制代码
#include<iostream>
#include<algorithm>

using namespace std;

int primes[N],cnt;
bool st[N];

void get_primes(int n)
{
    for(int i = 2;i<= n;i ++)
    {
        if(!st[i]) primes[cnt ++] = i;
        for(int j = 0;primes[j] <= n / i;j ++)
        {
            st[primes[j] * i = true;
            if(i % primes[j] == 0) break;  //primes[j]一定是i的最小质因子
         }
    }
}

1.2约数

试除法求约数

cpp 复制代码
vector<int> get_divisors(int n)
{
    vector<int> res;
    
    for(int i = 1;i <= n / i;i ++)
        if(n % i == 0)
        {
            res.push_back(i);
            if(i != n / i) res.push_back(n / i);
        }
    sort(res.begin(),res.end());
    return res;
}

约数个数与 约数之和

欧几里得算法

cpp 复制代码
//返回a与b的最大公约数
int gcd(int a,int b)
{
    return b ? gcd(b,(a % b) : a);
}

二、欧拉定理

2.1欧拉函数

定义:X(n)表示1~n中与n互质的个数

算法步骤:

  1. 从1~N中去掉p1,p2,...,pk的倍数
  2. 加上所有Pi * Pj的倍数
  3. 减去所有Pi * Pj * Pk的倍数
cpp 复制代码
#include<iostream>
#include<cstring>
#include<algorithm>

using namespace std;

int main()
{
    int n;
    cin>>n;

    while(n --)
    {
        int a;
        cin>>a;

        int res = a;
        //分解质因数
        for(int i = 2 ;i <= a;i ++)
        {
            if(a % i == 0)
            {
                res = res / i * (i - 1);
                while (a % i == 0) a /= i;
            }
        }
        if(a > 1) res = res / a * (a - 1);

        cout<<res<<endl;
    }
    return 0;
}

快速幂

cpp 复制代码
#include<iostream>
#include<algorithm>

using namespace std;

typedef long long LL;

//求a^k % p
int main(int a,int k,int p)
{
    int res = 1;
    while(k)
    {
        //如果当前k的末位为1,则
        if( k & 1) res = (LL)res * a % p;
        //删除k的末位
        k >>= 1;
        //把a平方
        a = (LL) a * a % p;
    }
    return res;
}
int main()
{
    int n;
    scanf("%d",&n);
    
    while(n --)
    {
        int a,k,p;
        scanf("%d%d%d",&a,&k,&p);
        
        printf("%d\n",qmi(a,k,p));
    }
    return 0;
}
相关推荐
就是帅我不改1 分钟前
告别996!高可用低耦合架构揭秘:SpringBoot + RabbitMQ 让订单系统不再崩
java·后端·面试
hhzz14 分钟前
Maven项目中settings.xml终极优化指南
java·jdk·maven
weixin_3077791315 分钟前
C++进程监视器与自动启动程序
开发语言·c++·算法
草莓熊Lotso35 分钟前
【C语言强化训练16天】--从基础到进阶的蜕变之旅:Day12
c语言·开发语言·c++·刷题
hqxstudying37 分钟前
MyBatis 和 MyBatis-Plus对比
java·数据库·mysql·mybatis
不喜欢学数学er1 小时前
算法第五十三天:图论part04(第十一章)
开发语言·python·图论
源码哥_博纳软云1 小时前
JAVA国际版多商户运营版商城系统源码多商户社交电商系统源码支持Android+IOS+H5
android·java·ios·微信·微信小程序·小程序·uni-app
你怎么知道我是队长1 小时前
python---构造函数、析构函数
开发语言·python
猿java1 小时前
为什么复杂的架构一定要做分层设计?
java·面试·架构
whitepure1 小时前
万字详解常用数据结构(Java版)
java·数据结构·后端