第十四届蓝桥杯大赛软件赛省赛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))
相关推荐
王琦0318几秒前
Python 0909
前端·javascript·python
念念01075 分钟前
Flask 博客系统(Flask Blog System)
后端·python·flask
tianyuanwo12 分钟前
pyproject.toml 的历史背景和原理
python·pyproject·setup.py
蒋星熠28 分钟前
中间件架构设计与实践:构建高性能分布式系统的核心基石
开发语言·数据库·分布式·python·中间件·性能优化·硬件工程
海天一色y3 小时前
Pycharm(二十一)递归删除文件夹
ide·python·pycharm
汉克老师7 小时前
第十四届蓝桥杯青少组C++选拔赛[2023.2.12]第二部分编程题(5、机甲战士)
c++·算法·蓝桥杯·01背包·蓝桥杯c++·c++蓝桥杯
乔巴先生248 小时前
LLMCompiler:基于LangGraph的并行化Agent架构高效实现
人工智能·python·langchain·人机交互
张子夜 iiii9 小时前
实战项目-----Python+OpenCV 实现对视频的椒盐噪声注入与实时平滑还原”
开发语言·python·opencv·计算机视觉
Jared_devin9 小时前
二叉树算法题—— [蓝桥杯 2019 省 AB] 完全二叉树的权值
数据结构·c++·算法·职场和发展·蓝桥杯
困鲲鲲10 小时前
Flask 核心基础:从 路由装饰器 到 __name__ 变量 的底层逻辑解析
python·flask