第十四届蓝桥杯大赛软件赛省赛Python 研究生组:4.互质数的个数

题目1 互质数的个数

给定 a,b,求 1≤x<ab 中有多少个 x 与 ab 互质。

由于答案可能很大,你只需要输出答案对 998244353 取模的结果。

输入格式

输入一行包含两个整数分别表示 a,b,用一个空格分隔。

输出格式

输出一行包含一个整数表示答案。

数据范围

对于 30% 的评测用例, a b ≤ 1 0 6 ab≤10^6 ab≤106;

对于 70% 的评测用例, a ≤ 1 0 6 , b ≤ 1 0 9 a≤10^6,b≤10^9 a≤106,b≤109;

对于所有评测用例, 1 ≤ a ≤ 1 0 9 , 1 ≤ b ≤ 1 0 18 1≤a≤10^9,1≤b≤10^{18} 1≤a≤109,1≤b≤1018。

输入样例1:
复制代码
2 5
输出样例1:
复制代码
16
输入样例2:
复制代码
12 7
输出样例2:
复制代码
11943936

思路

  1. 主要考察数学知识:欧拉公式求小于x的互质的个数
  2. 互质的含义就是:两个数的最大公约数是1
  3. 另外注意到数据范围较大,需要利用快速幂or pow(a,b,mod)

python代码

python 复制代码
a,b=map(int,input().split())
mod=998244353

def eular(x):
    global mod
    res=x
    for i in range(2,int(x**0.5)+1):
        if x%i==0:
            while x%i==0:
                x//=i
            res=res//i*(i-1)
    if x>1:
        res=res//x*(x-1)
    return res

ans=1
def fast(a,b):
    global ans
    while b>0:
        if b&1:
            ans=ans*a%mod
        a=a*a%mod
        b>>=1
    return ans
ans=fast(a,b-1)*eular(a)%mod
print(ans)

知识点

蓝桥杯笔记:蓝桥杯备赛笔记

  1. 欧拉公式
  2. 手写快速幂( 1 0 18 内数据 10^{18}内数据 1018内数据)
  3. eular(a^b)%mod==a^(b-1)*eular(a)%mod==pow(a,b-1,mod)*(eular(a))
相关推荐
明月_清风13 分钟前
FastAPI 从入门到实战:3 分钟构建高性能异步 API
后端·python·fastapi
bellus-19 分钟前
ubuntu26测试win10的ollama大模型性能
python
水木流年追梦21 分钟前
大模型入门-Reward 奖励模型训练
开发语言·python·算法·leetcode·正则表达式
JavaWeb学起来21 分钟前
Python学习教程(六)数据结构List(列表)
数据结构·python·python基础·python教程
liuyunshengsir34 分钟前
PyTorch 动态量化(Dynamic Quantization)
人工智能·pytorch·python
电子云与长程纠缠43 分钟前
UE5制作六边形包裹球体效果
开发语言·python·ue5
DFT计算杂谈1 小时前
KPROJ编译教程
java·前端·python·算法·conda
念恒123061 小时前
Python(循环中断)
开发语言·python
tsfy20032 小时前
Python 处理中文文件名的3个坑(附 Flask 上传解决函数)
开发语言·python·flask·文件上传·中文编码
AI技术控2 小时前
KV Cache 缓存机制的原理和应用:从 Transformer 推理到大模型服务优化
人工智能·python·深度学习·缓存·自然语言处理·transformer