洛谷 模板汇总 算法基础 python解析

文章目录

  • P1226 【模板】快速幂
    • 题目分析
    • 代码
  • P3367 【模板】并查集
    • 题目分析
    • 代码
  • P3378 【模板】堆
    • 题目分析
    • 代码
  • P3383 【模板】线性筛素数
    • 题目分析
    • 代码
  • P3366 【模板】最小生成树
    • 题目分析
    • 代码
  • P3390 【模板】矩阵快速幂
    • 题目分析
    • 代码
  • 【模板】单源最短路径
    • 题目分析
    • 代码

P1226 【模板】快速幂

题目地址:【模板】快速幂

题目分析

快速幂原理:
以这个为例 a = 2 , b = ( 11 ) 10 = ( 1011 ) 2 a=2,b=(11)_{10}=(1011)_{2} a=2,b=(11)10=(1011)2,求 2 11 。 2^{11}。 211
2 11 = 2 8 × 2 0 × 2 2 × 2 1 2^{11}=2^{8} \times 2^{0} \times 2^{2} \times 2^{1} 211=28×20×22×21,幂的次数正好对应 ( 1011 ) 2 (1011)_{2} (1011)2
那么只需循环判断即可。

“”“
ans = 1
base = a = 2^1第一次循环
b = 12 = '0b1011'  # 0b是python里的二进制标志
1 = '0b0001'
b & 1 = '0b0001' = 1
ans = ans * base = 1 * 2 = 2
base = 2^2
b = b >> 1 = '0b101'第二次循环
b & 1 = '0b001' = 1
ans = 2 * 2^2 = 2^3
base = 2^4
b = b >> 1 = '0b10'第三次循环
b & 1 = '0b00' = 0
base = 2^8
b = b >> 1 = '0b1'第四次循环
b & 1 = '0b1' = 1
ans = 2^3 * 2^8 = 2^11
base = 2^16
b = b >> 1 = 0 # b=0 退出循环最后的ans = 2^11.
计算次数由O(b) => log(b)
”“”

通常对于快速幂一般结合取余(mod)来考。了解原理即可
( A + B ) m o d P = ( A m o d P + B m o d P ) m o d P (A+B) \, mod \, P = (A \, mod \, P + B \, mod \,P)\,mod\,P (A+B)modP=(AmodP+BmodP)modP
( A × B ) m o d P = ( ( A m o d P ) × ( B m o d P ) ) m o d P (A \times B)\,mod\,P=((A\,mod\,P) \times (B\,mod\,P))\,mod\,P (A×B)modP=((AmodP)×(BmodP))modP
见代码。

代码

# 快速幂
def quickpower(a: int, b: int):base = aans = 1while b > 0:if b & 1:ans *= basebase *= baseb = b >> 1return ans# 快速幂应用--取余 
def quickmod(a: int, b: int):base = aans = 1while b > 0:if b & 1:ans *= baseans %= pbase *= basebase %= pb = b >> 1return ansa, b, p = map(int, input().split())
# 只能过一半百分之五十
# ans = quickpower(a, b) % p
# print(f"{a}^{b} mod {p}={ans}")
# AC
ans = quickmod(a, b)
print(f"{a}^{b} mod {p}={ans}")

P3367 【模板】并查集

题目地址:【模板】并查集

题目分析

这个找并集就是找他们共同的祖先。就以题目例题来看.

"""
n = 4, m = 7
fa = [0, 1, 2, 3, 4]① 1、2的祖先分别为1、2 不相等,输出N
② 将1、2合并,设2为1的祖先,fa = [0, 2, 2, 3, 4]
③ 1、2的祖先分别为2、2 相等,输出Y
④ 将3、4合并,设4为3的祖先,fa = [0, 2, 2, 4, 4]
⑤ 1、4的祖先分别为2、4 不相等,输出N
⑥ 将2、3合并,设3是2的祖先,fa = [0, 2, 3, 4, 4]
⑦ 1的爸爸是2,2的爸爸是3,3的爸爸是4 => 1的祖先是44的祖先是4相等输出Y
"""

这个找祖先的函数递归一下就可以了。
见代码

代码

# 递归找爹
def find(x):if x == fa[x]:return xfa[x] = find(fa[x])return fa[x]n, m = map(int, input().split())
fa = [i for i in range(n+1)]  # 初始化自己为爹
for _ in range(m):z, x, y = map(int, input().split())a, b = find(x), find(y)if z == 1:fa[a] = belse: # z == 2if a == b:print('Y')else:print('N')         

P3378 【模板】堆

题目地址:【模板】堆

题目分析

代码


P3383 【模板】线性筛素数

题目地址:【模板】线性筛素数

题目分析

代码


P3366 【模板】最小生成树

题目地址:【模板】最小生成树

题目分析

代码


P3390 【模板】矩阵快速幂

题目地址:【模板】矩阵快速幂

题目分析

代码


【模板】单源最短路径

见【模板】单源最短路径

题目分析

见【模板】单源最短路径

代码

见【模板】单源最短路径


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/156301.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

5.基于飞蛾扑火算法(MFO)优化的VMD参数(MFO-VMD)

代码的使用说明 基于飞蛾扑火算法优化的VMD参数 优化算法代码原理 飞蛾扑火优化算法(Moth-Flame Optimization,MFO)是一种新型元启发式优化算法,该算法是受飞蛾围绕火焰飞行启发而提出的,具有搜索速度快、寻优能力强的…

事件溯源(Event Sourcing)和命令查询责任分离(CQRS)经验

这篇文章是实现一个基于 CQRS 和事件溯源原则的应用程序,描述这个过程的方式,我相信分享我面临的挑战和问题可能对一些人有用。特别是如果你正在开始自己的旅程。 业务背景 项目的背景与空中交通管理(ATM)领域相关。我们为一个 …

C++优先队列的使用

1. 什么是priority_queue priority_queue是C中的容器&#xff0c;实现优先队列。由于底层采用堆实现&#xff0c;所以插入和删除操作的时间复杂度为O(logn)&#xff0c;查找队首元素的时间复杂度为O(1)。 2. 构造priority_queue 【1】使用priority_queue需要先包含头文件<…

C++学习 --list

目录 1&#xff0c; 什么是list 2&#xff0c; 创建 2-1&#xff0c; 标准数据类型 2-2&#xff0c; 自定义数据类型 2-3&#xff0c; 其他创建方式 3&#xff0c; 操作list 3-1&#xff0c; 赋值 3-2&#xff0c; 添加元素 3-2-1&#xff0c; 添加元素(assign) 3-2-…

动手学深度学习——循环神经网络的简洁实现(代码详解)

文章目录 循环神经网络的简洁实现1. 定义模型2. 训练与预测 循环神经网络的简洁实现 # 使用深度学习框架的高级API提供的函数更有效地实现相同的语言模型 import torch from torch import nn from torch.nn import functional as F from d2l import torch as d2lbatch_size, …

卷积核的形象化解释

卷积核是在卷积神经网络&#xff08;CNN&#xff09;中使用的一种重要工具&#xff0c;它可以对输入数据进行特征提取和特征映射。在图像处理中&#xff0c;卷积核通常用于检测图像中的边缘、纹理、颜色等特征&#xff0c;从而帮助网络识别图像中的物体或模式。 为了形象化地解…

【蓝桥杯单片机(27)】超声波测距

一、简要说明 超声波测距传感器,一个发出超声波(A),另一个接收超声波(B) A如何发出超声波?给A的引脚一个持续的高低电平(方波)即可发出超声波。 B如何确认超声波已收到?B的一个引脚由低电平变为高电平即是收到了超声波。 因此,超声波测距分为两步,第一步发出超声波…

【Linux】文件操作

欢迎来到Cefler的博客&#x1f601; &#x1f54c;博客主页&#xff1a;那个传说中的man的主页 &#x1f3e0;个人专栏&#xff1a;题目解析 &#x1f30e;推荐文章&#xff1a;题目大解析&#xff08;3&#xff09; 目录 &#x1f449;&#x1f3fb;文件是什么&#xff1f;&am…

艾泊宇产品战略:用户满意度是衡量产品成功的关键指标

在当今的商业环境中&#xff0c;企业做产品面临着巨大的挑战。 他们需要创造出满足用户需求的产品&#xff0c;同时还要考虑如何实现商业目标。 企业在做产品过程中必须时刻保持警惕&#xff0c;避免陷入“自嗨”的境地。 自嗨是指企业在设计和开发产品时&#xff0c;过于关…

Python3.11+Pyside6开发电影下载程序

VideoSave是一款使用Python3.11Pyside6编写的提供下载电影/电视剧的软件&#xff0c;支持注册、登录、搜索、下载、查看日志等功能&#xff0c;提供了Window、Mac系统安装包。 先上效果图 提供功能 节省寻找资源的时间 ⌚️模糊搜索指定影片 &#x1f434;查看影片下载日志 &…

【spring】如何解决循环依赖

概念 Spring循环依赖是指两个或多个Bean之间相互依赖&#xff0c;形成了双向依赖关系&#xff0c;导致Spring无法正确地完成Bean的创建和初始化。 Spring框架为了解决循环依赖问题&#xff0c;采用了三级缓存的方式来解决。 第一级缓存&#xff1a;单例池中的三级缓存 每个B…

Mac如何搭建Vue项目

目录 一、安装node 二、安装NPM 1、本地安装和全局安装 2、通过Node.js官方安装程序安装 3、通过Homebrew安装 三、NPM常用命令 1、查看模块的版本号 2、安装指定版本 3、卸载模块 4、更新模块 5、查看模块信息 6、查看模块地址 7、更新命令 8、卸载NPM 四、安装…

设计模式 - 概览

一、概念 分为三大类、23中具体设计模式。 类型原理具体模式创建型封装了具体类的信息&#xff0c;隐藏了类的实例化过程。 单例模式&#xff08;Singleton&#xff09; 工厂方法模式&#xff08;Factory Method&#xff09; 抽象工厂模式&#xff08;Abstract Factory&#xf…

观光奶牛 (01分数规划、负环)

01分数规划问题&#xff1a;类似于观光奶牛这个题中的&#xff0c;求的路径上的点权值和与边权值和的商最大最小。 当前问题的推到如下&#xff1a; 该问题其实可以用二分图来解决&#xff0c; 在不断的二分答案中获取符合条件的最大值。然后问题就转化为如何是否存在和为mid的…

Vue3中的pinia使用,入门教程

文章目录 文章目录 pinia组成部分 pinia使用流程 注意Store获取到后不能解构&#xff0c;否则失去响应式 一、pinia原理&#xff1f; 功能&#xff1a;管理全局共享数据&#xff0c;pinia与vuex功能一样优势&#xff1a;pinia相对于vuex增加了对ts的支持&#xff0c;对响应式的…

程序员如何“升级打怪”?我用了这几个“歪瓜”!

不会吧&#xff1f;不会吧&#xff1f;计算机本命专业出身、以及半路出家的&#xff0c;混了几年了&#xff0c;还在新手村&#xff1f;对得起这几年摸的鱼&#xff1f; 思考一下&#xff1a;如何从小白一跃为大师&#xff0c;从此走上人生巅峰、迎娶白富美&#xff1f;变强只…

Java --- JVM之垃圾回收相关知识概念

目录 一、System.gc() 二、内存溢出与内存泄漏 2.1、内存溢出 2.2、内存泄漏 三、Stop the world 四、垃圾回收的并行与并发 4.1、并发 4.2、并行 4.3、并行 vs 并发 4.4、垃圾回收的并发与并行 五、安全点与安全区域 5.1、安全点 5.2、安全区域 六、引用 6.1…

3.基于多能互补的热电联供微网优化运行复现(matlab代码)

0.代码链接 基于多能互补的热电联供微电网/综合能源系统优化运行&#xff08;Matlab程序Yalmip&#xff0b;Cplex求解&#xff09;_工业综合能源系统资源-CSDN文库 2. 主要内容&#xff1a;代码主要做的是多能互补的热电联供型微网优化运行模型&#xff0c;在需求侧对负荷类型…

hive数据库将非分区表数据迁移到分区表

文章目录 一、非分区表数据迁移到分区表 一、非分区表数据迁移到分区表 业务运行一段时间后非分区表的数据量非常大&#xff0c;需要创建一张分区表并将数据迁移到分区表中。 原表建表语句&#xff1a; create table user(id String default null comment 主键id,name St…

c# 文件操作

文件操作 namespace demo1;class proj {/// <summary>///文件&#xff1a;///注册表是Micrsoft windows 中的一个重要的数据库&#xff0c;用于存储系统和应用恒旭的设置信息///主要了解文件和注册表的创建、打开、读取、写入、修改、删除/// </summary>//////文件…