当前位置: 首页 > news >正文

Python|蓝桥杯进阶第五卷——数论

在这里插入图片描述

欢迎交流学习~~


专栏: 蓝桥杯Python组刷题日寄


蓝桥杯进阶系列:

🏆 Python | 蓝桥杯进阶第一卷——字符串
🔎 Python | 蓝桥杯进阶第二卷——贪心
💝 Python | 蓝桥杯进阶第三卷——动态规划
✈️ Python | 蓝桥杯进阶第四卷——图论
🌞 Python | 蓝桥杯进阶第五卷——数论
💎 Python | 蓝桥杯进阶第六卷——搜索

Python|蓝桥杯进阶第五卷——数论

  • 🎁 买不到的数目
  • 🌲 幂方分解
  • 💡 麦森数
  • 🍞 欧拉函数


🎁 买不到的数目

题目:
时间限制:
1s

内存限制:
128MB

题目描述:
小明开了一家糖果店。他别出心裁:把水果糖包成 4 颗一包和 7 颗一包的两种。糖果不能拆包卖。
小朋友来买糖的时候,他就用这两种包装来组合。当然有些糖果数目是无法组合出来的,比如要买 10 颗糖。
你可以用计算机测试一下,在这种包装情况下,最大不能买到的数量是17。大于17的任何数字都可以用 47 组合出来。
本题的要求就是在已知两个包装的数量时,求最大不能组合出的数字。

输入描述:
两个正整数,表示每种包装中糖的颗数(都不多于1000)

输出描述:
一个正整数,表示最大不能买到的糖数

样例输入:
4 7

样例输出:
17


解题思路

这里需要先确定上边界,然后针对小于其的数逐个判断即可。(代码1)

借助数论中的结论:自然数 a,ba,ba,b 互质,则不能表示成 ax+byax+byax+byx,yx,yx,y 为非负整数)的最大整数是 ab−a−bab-a-babab,本题中所给出的数据全部为质数,因此可以使用。(代码2)


参考代码

# 代码1
from math import gcd
def check(a, b, n):if n%a == 0 or n%b == 0:return Truex = n//amod = n%afor i in range(x+1):if (i*a+mod)%b == 0:return Truereturn Falsedef func(a, b):# 计算上边界,这里取最小公倍数max_num = (a*b)//gcd(a, b)for i in range(max_num-1, 0, -1):if not check(a, b, i):print(i)breaka, b = map(int, input().split())
func(a, b)
# 代码2
n,m = map(int, input().strip().split()) 
print(n*m-m-n)

🌲 幂方分解

题目:
时间限制:
1s

内存限制:
128MB

题目描述:
任何一个正整数都可以用 2 的幂次方表示。例如:
137=2^7+2^3+2^0
同时约定方次用括号来表示,即 ab 可表示为 a(b)

由此可知,137 可表示为:
2(7)+2(3)+2(0)
进一步:7= 2^2+2+2^02^12 表示)
3=2+2^0
所以最后 137 可表示为:
2(2(2)+2+2(0))+2(2+2(0))+2(0)

又如:
1315=2^10+2^8+2^5+2+2^0
所以 1315 最后可表示为:
2(2(2+2(0))+2)+2(2(2+2(0)))+2(2(2)+2(0))+2+2(0)

输入描述:
输入包含一个正整数 N(N<=20000),为要求分解的整数。

输出描述:
程序输出包含一行字符串,为符合约定的 n02 表示(在表示中不能有空格)

样例输入:
1315

样例输出:
2(2(2+2(0))+2)+2(2(2+2(0)))+2(2(2)+2(0))+2+2(0)


解题思路

可以通过每个数的二进制来得到其二次幂分解:
比如样例中的 1315,其对应的二进制数为:0b10100100011
其中 1 对应的位置由高到低为:11 9 6 2 1
因此其对应二次幂分解为:1315 = 2^10 + 2^8 + 2^5 +2 ^1 + 2^0

对于 0 次幂和 1 次幂特别处理,而对于高次幂,通过递归调用。
注意:要从高次幂开始处理。

具体见参考代码及其注释。

参考代码

def trans(n):# 转为 2 进制后再处理tmp = list(bin(n))# 去除 2 进制前面的 0bn = tmp[2:]# 转换为整数n = [int(i) for i in n]res = ''for i in range(1, len(n) + 1):if n[len(n) - i]:if len(n) - i == 0:# 处理 0 次幂res += '2(0)+'elif len(n) - i == 1:# 处理 1 次幂res += '2+'else:# 其余情况,递归调用res += '2(' + trans(len(n) - i) + ')+'# 最后res会有一个 '+' 需要去除return res[:-1]if __name__ == '__main__':n = int(input())print(trans(n))

💡 麦森数

题目:
时间限制:
3s

内存限制:
192MB

题目描述:
形如 2^p-1 的素数称为麦森数,这时 p 一定也是个素数。但反过来不一定,即如果 p 是个素数,2^p-1不一定也是素数。到1998年底,人们已找到了 37 个麦森数。最大的一个是p=3021377,它有 909526 位。麦森数有许多重要应用,它与完全数密切相关。
任务:从文件中输入 p(1000 < p < 3100000),计算 2^p-1 的位数和最后 500 位数字(用十进制高精度数表示)

输入描述:
文件中只包含一个整数 p(1000 < p < 3100000)

输出描述:
第一行:十进制高精度数 2^p-1的位数。
第2-11行:十进制高精度数 2^p-1 的最后 500 位数字。(每行输出 50 位,共输出 10 行,不足 500 位时高位补 0
不必验证 2^p-1p 是否为素数。

样例输入:
1279

样例输出:

386
00000000000000000000000000000000000000000000000000
00000000000000000000000000000000000000000000000000
00000000000000104079321946643990819252403273640855
38615262247266704805319112350403608059673360298012
23944173232418484242161395428100779138356624832346
49081399066056773207629241295093892203457731833496
61583550472959420547689811211693677147548478866962
50138443826029173234888531116082853841658502825560
46662248318909188018470682222031405210266984354887
32958028878050869736186900714720710555703168729087

解题思路

对于一个十进制数 k,其位数 A 为:A = int(log10(k) + 1)

因为当 p 取较大值时,整个数过大,考虑到最后只需要输出 500 位,我们将其对 10**500 取幂,之后再按照要求格式输出。

具体见参考代码和注释。


参考代码

from math import log10 as lg
p = int(input())
print(int(p * lg(2)) + 1)num = 2**p - 1
# 预处理,因为最后只需要500位,对 10**500 取幂
num = num % (10**500)
res = []
# 计算结果
for i in range(500):res.append(num % 10)num //= 10# 按照要求打印
for i in range(499, -1, -1):print(res[i], end='')if i % 50 == 0:print('')

🍞 欧拉函数

题目:
时间限制:
1s

内存限制:
128MB

题目描述:

给定一个大于 1,不超过 2000000 的正整数 n,输出欧拉函数,phi(n) 的值。
如果你并不了解欧拉函数,那么请参阅提示。

提示:
欧拉函数 phi(n) 是数论中非常重要的一个函数,其表示 1n-1 之间,与 n 互质的数的个数。显然的,我们可以通过定义直接计算 phi(n)
当然,phi(n) 还有这么一种计算方法。
首先我们对 n 进行质因数分解,不妨设 n=p1^a1 * p2^a2 * ... * pk^ak (这里 a^b 表示 ab次幂,p1pkk 个互不相同的质数,a1ak 均为正整数),那么
phi(n)=n(1-(1/p1))(1-(1/p2))....(1-(1/pk))
稍稍化简一下就是
phi(n)=n(p1-1)(p2-1)...(pk-1)/(p1*p2*...*pk)

计算的时候小心中间计算结果超过 int 类型上界,可通过调整公式各项的计算顺序避免(比如先做除法)!

输入描述:
在给定的输入文件中进行读入:
一行一个正整数 n。 不超过 2000000 的正整数 n.

输出描述:
将输出信息输出到指定的文件中:
一行一个整数表示 phi(n)

样例输入:
17

样例输出:
16


解题思路

直接按照定义来写即可


参考代码

from math import gcd
n = int(input())
count = 0
for i in range(1,n):if gcd(i,n)==1:count += 1
print(count)

相关文章:

Python|蓝桥杯进阶第五卷——数论

欢迎交流学习~~ 专栏&#xff1a; 蓝桥杯Python组刷题日寄 蓝桥杯进阶系列&#xff1a; &#x1f3c6; Python | 蓝桥杯进阶第一卷——字符串 &#x1f50e; Python | 蓝桥杯进阶第二卷——贪心 &#x1f49d; Python | 蓝桥杯进阶第三卷——动态规划 ✈️ Python | 蓝桥杯进阶…...

用Python实现单例模式

什么是单例模式单例模式是指在内存中只会创建且仅创建一次对象的设计模式。在程序中多次使用同一个对象且作用相同时&#xff0c;为了防止频繁地创建对象使得内存飙升&#xff0c;单例模式可以让程序仅在内存中创建一个对象&#xff0c;让所有需要调用的地方都共享这一单例对象…...

交叉编译说明:工具链安装和环境变量配置

目录 一 简单了解交叉编译 ① 什么是交叉编译 ② 为什么需要交叉编译 ③ 宿主机和目标机 二 搭建交叉编译工作环境 ① 安装工具链 ② 配置环境变量 ● 配置临时环境变量 ● 配置永久环境变量 三 交叉编译宿主机和目标机 ● 宿主机编译生成的可执行文件下载到目…...

文件上传的多种利用方式

文件上传的多种利用方式 文件上传漏洞除了可以通过绕过检测进行webshell的上传之外&#xff0c;还有多种其它的漏洞可以进行测试。 XSS漏洞 文件名造成的XSS 当上传任何文件时&#xff0c;文件名肯定是会反显示在网页上&#xff0c;可以使用 XSS Payload做文件名尝试将其上传到…...

盘一盘C++的类型描述符(二)

先序文章请看 盘一盘C的类型描述符&#xff08;一&#xff09; 稍微组合一下的复杂类型 数组指针类型的数组类型 数组的指针类型我们已经了解了&#xff0c;那么&#xff0c;以这种类型作为元素的数组类型怎么搞&#xff1f; using type int (*)[3]; // 元素类型是数组指针…...

慎投,Frontiers这本期刊显示on hold中

什么是“On Hold”&#xff1f; 该期刊因为质量问题正在被进行重新评估&#xff1b;在重新评估过程中&#xff0c;不会检索新发表的文章。该期刊因为质量问题正在被进行重新评估&#xff1b;在重新评估过程中&#xff0c;不会检索新发表的文章。根据选择标准&#xff0c;在最严…...

Winform控件开发(21)——ProgressBar(史上最全)

一、属性 1、Name 用于获取控件对象 2、Anchor 锚定控件对于父控件的位置 3、BackColor 背景色 4、ContextMenuStrip 关联的上下文菜单 5、Cursor 鼠标移动到控件上显示的光标 6、Dock 停靠在父控件的位置 7、Enabled 是否启动该控件,false时事件都不能触发 8、…...

校招失败后,在外包公司熬了 2 年终于进了字节跳动,竭尽全力....

其实两年前校招的时候就往字节投了一次简历&#xff0c;结果很明显凉了&#xff0c;随后这个理想就被暂时放下了&#xff0c;但是这个种子一直埋在心里这两年除了工作以外&#xff0c;也会坚持写博客&#xff0c;也因此结识了很多优秀的小伙伴&#xff0c;从他们身上学到了特别…...

UniApp + SpringBoot 实现接入支付宝支付功能和退款功能

一、支付宝开放平台设置 注册支付宝支付功能需要个体工商户或企业才可以&#xff01;需要有营业执照才能去申请哦&#xff01; 1、登录到控制台 进入支付宝开放平台 控制台 2、开发设置 3、产品绑定APP支付 如果没有绑定APP支付就会报商家订单参数异常&#xff0c;请重新发起…...

初识进程

文章目录一、进程的概念1. 进程是什么及进程的管理2. Linux 下的 pcb3. 系统调用接口 getpid 和 getppid4. 系统调用接口 fork一、进程的概念 1. 进程是什么及进程的管理 在 Linux下 ./binaryfile 运行一个程序或者在 Windows下双击运行一个程序时&#xff0c;程序就变成了一个…...

SOAP传输协议

一.HTTP传输协议 超文本传输协议&#xff08;HyperText Transfer Protocol&#xff0c;缩写&#xff1a;HTTP&#xff09;&#xff0c;它是基于请求-响应的模式协议&#xff0c;客户端发出请求&#xff0c;服务器端给出响应并返回请求内容。方法如下&#xff0c;HTTP传输协议常…...

<Linux>进程控制

进程控制 文章目录进程控制一、进程创建1.fork函数认识2.写时拷贝3.fork常规用法4.fork调用失败的原因二、进程终止1.进程退出场景2.进程退出码3.进程退出的方式三、进程等待1.进程等待是什么&#xff1f;2.进程等待的必要性3.进程等待的方法3.1.wait函数3.2.waitpid函数4.如何…...

有手就行 -- 搭建图床(PicGo+腾讯云)

&#x1f373;作者&#xff1a;贤蛋大眼萌&#xff0c;一名很普通但不想普通的程序媛\color{#FF0000}{贤蛋 大眼萌 &#xff0c;一名很普通但不想普通的程序媛}贤蛋大眼萌&#xff0c;一名很普通但不想普通的程序媛&#x1f933; &#x1f64a;语录&#xff1a;多一些不为什么的…...

“蓝桥杯”递推和递归(一)——取数位

1. 算法简介 递推和递归虽然叫法不同&#xff0c;但它们的基本思想是一致的&#xff0c;在很多程序中&#xff0c;这两种算法可以通用&#xff0c;不同的是递推法效率更高&#xff0c;递归法更方便阅读。 &#xff08;1&#xff09;递推法 递推法是一种重要的数学方法&#…...

蓝桥杯·3月份刷题集训Day02

本篇博客旨在记录自已打卡蓝桥杯3月份刷题集训&#xff0c;同时会有自己的思路及代码解答希望可以给小伙伴一些帮助。本人也是算法小白&#xff0c;水平有限&#xff0c;如果文章中有什么错误之处&#xff0c;希望小伙伴们可以在评论区指出来&#xff0c;共勉&#x1f4aa;。 文…...

python --获取内网IP地址

方法一 import socketdef get_local_ip_address():ip_address try:# 获取本机主机名hostname socket.gethostname()# 获取本机IPip_address socket.gethostbyname(hostname)except:passreturn ip_address方法二 import subprocessdef get_local_ip_address():ip_address …...

如何衡量你的Facebook广告活动的成功

投入大量资金和资源在Facebook广告上并不总能带来预期的回报&#xff0c;这很可能是由于缺乏恰当的衡量广告活动成功的方法。在这篇文章中&#xff0c;我们将介绍一些关键的指标&#xff0c;帮助你更好地了解如何衡量你的Facebook广告活动的成功。1.费用每次点击&#xff08;CP…...

Linux对一个目录及其子目录所有文件添加权限

1、chmod指令 chmod是一个改变用户拥有指定文件的权限的命令.r:只读,w:写,x执行.也可以用数字 -rw------- (600) -- 只有属主有读写权限。 -rw-r--r-- (644) -- 只有属主有读写权限&#xff1b;而属组用户和其他用户只有读权限。 -rwx------ (700) -- 只有属主有读、写、执…...

宝刀未老?低代码何德何能受大厂们的推崇

风口之下&#xff0c;低代码蓬勃发展&#xff0c;本文从国内低代码的走红现象引入&#xff0c;浅析低代码发展中的变化趋势&#xff0c;重点探讨如此趋势之下&#xff0c;国内大厂如何通过低代码实现了良性发展。 一、国内爆火的低代码 据Gartner最新报告显示&#xff0c;到2…...

智能扑克牌识别软件(Python+YOLOv5深度学习模型+清新界面)

摘要&#xff1a;智能扑克牌识别软件利用视觉方法检测和识别日常扑克牌具体花色与数字&#xff0c;快速识别牌型并标注结果&#xff0c;帮助计算机完成扑克牌对战的前期识别步骤。本文详细介绍基于深度学习的智能扑克牌识别软件&#xff0c;在介绍算法原理的同时&#xff0c;给…...

大模型MoE架构原理与实战:理解专家路由与负载均衡

1. 这不是“参数越多越强”的简单故事&#xff1a;拆解大模型里那个被悄悄藏起来的“开关”你肯定见过这类标题&#xff1a;“GPT-4参数量突破1.8万亿&#xff01;”、“DeepSeek-R1狂堆6710亿参数&#xff01;”——光看数字&#xff0c;像在比谁家粮仓堆得更高。但真正玩过模…...

别再买成品模块了!手把手教你用LM2596S-ADJ自制一个可调稳压电源(附PCB布线避坑指南)

从零打造高精度可调电源&#xff1a;LM2596S-ADJ实战设计与避坑全攻略 当你需要为创客项目或实验设备搭建一个灵活可靠的电源系统时&#xff0c;成品模块虽然方便&#xff0c;却失去了DIY的乐趣和深度定制的可能。本文将带你深入LM2596S-ADJ芯片的核心设计&#xff0c;从元器件…...

丙级管道井防火门:规范要求、参数标准与工程应用要点

高层建筑消防体系中&#xff0c;管道井、电缆井属于贯穿整栋建筑的竖向竖井&#xff0c;是火势垂直蔓延的高危通道。根据《建筑设计防火规范》及新版《建筑防火通用规范》要求&#xff0c;建筑各类竖向管道井、强弱电井的检查检修门&#xff0c;必须统一采用丙级防火门&#xf…...

生成式AI绘画的版权困局与人机协同新范式

1. 这不是技术升级&#xff0c;而是一场创作权的重新分配“Paint, Pixels, and Plagiarism”——光看这个标题&#xff0c;你就能闻到火药味。它没在讲AI怎么画得更像梵高&#xff0c;也没教你怎么用Stable Diffusion生成赛博朋克海报&#xff1b;它直指一个所有画师、设计师、…...

Kolmogorov-Arnold网络:函数表示论驱动的可解释神经架构

1. 这不是又一个“万能网络”——Kolmogorov-Arnold 网络到底在解决什么真问题&#xff1f;你可能刚在某篇预印本论文里看到“Kolmogorov-Arnold Network”这个名词&#xff0c;心里一咯噔&#xff1a;又来&#xff1f;又是那种名字听着像数学史课件、实操起来连 loss 曲线都跑…...

2026年最新实测15款降AIGC平台红黑榜!

2026 年的毕业季注定不平凡。教育部最新发布的《学术诚信管理规范》明确指出&#xff0c;本科毕业论文 AIGC 率不得超过 35%&#xff0c;而重点高校如清华、北大等已将标准压至 25% 以内&#xff0c;硕士及以上学位论文更是严格控制在 18% 以下。与此同时&#xff0c;各大检测平…...

WinUtil:一键解决Windows系统优化与软件安装的终极指南

WinUtil&#xff1a;一键解决Windows系统优化与软件安装的终极指南 【免费下载链接】winutil Chris Titus Techs Windows Utility - Install Programs, Tweaks, Fixes, and Updates 项目地址: https://gitcode.com/GitHub_Trending/wi/winutil 你是否曾为新电脑安装系统…...

C++中的函数知识点大全

函数的定义不能嵌套但调用可以嵌套在函数调用时&#xff0c;如某一默认参数要指明一个特定值&#xff0c;则有其之前所有参数都必须赋值赋默认实参时 一旦某个形参被赋予了默认值&#xff0c;它后面的所有形参都必须有默认值&#xff0c;因为设置默认参数的顺序是自右向左&…...

告别折腾:esir高大全版OpenWrt软路由安装后,必做的5项安全与性能优化设置

软路由进阶指南&#xff1a;esir高大全版OpenWrt安装后的5项关键优化 对于已经完成esir高大全版OpenWrt软路由基础安装的用户而言&#xff0c;真正的挑战才刚刚开始。一套配置得当的软路由系统不仅能提供稳定的网络环境&#xff0c;更能释放硬件全部潜能。本文将深入探讨五项关…...

5月最新10款降AI神器实测:哪个能降知网维普AI率,从99.5%降至3.8%可信吗?

2025 年 12 月 25 日知网 AIGC 检测系统升级&#xff0c;2026 年 4 月 27 日维普 AI 率检测平台升级…2026 毕业季&#xff0c;各大主流 AIGC 检测软件陆续升级系统&#xff0c;识别 AI 痕迹更加精准。 临近毕业&#xff0c;同学们看者飘红的 AIGC 检测报告、纷繁复杂的降 AI 系…...