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

【蓝桥杯】2025省赛PythonB组复盘

前言

昨天蓝桥杯python省赛B组比完,今天在洛谷上估了下分,省一没有意外的话应该是稳了。这篇博文是对省赛试题的复盘,所给代码是省赛提交的代码。PB省赛洛谷题单
在这里插入图片描述

试题 A: 攻击次数

在这里插入图片描述

思路

这题目前有歧义,一个回合到底是只有一个英雄攻击还是三个英雄都攻击。我以及洛谷测试是按照后者写的。

blood = 2025
for i in range(1,406):blood -= 5if i%2==1:blood -= 15if i%2==0:blood-=2if i%3==1:blood-=2if i%3==2:blood-=10if i%3==0:blood-=7if blood<=0:print(i)break

在这里插入图片描述

试题 B: 最长字符串

在这里插入图片描述

思路

居然考了文件的读写,并且txt有五万行,所以无法复制粘贴,考场上凭借一点点计算机二级的记忆写了出来,但是答案还是错了。

import os
good = [[] for i in range(12)]
max_len  = 0
max_word = 'a'
with open("F:\\2025pb\\LQSP2025_PB\\LQSP2025_PB\\words.txt", 'r') as f:while True:word = f.readline()if not word:breaklen_ = len(word)if len_==1:good[1].append([word])if len_>1:if sorted(word[:-1]) in good[len_-1]:good[len_].append(sorted(word))if len_ > max_len:max_len = len_max_word = wordif len_ == max_len:if word < max_word:max_word = wordf.close
print(max_word)

在这里插入图片描述

试题 C: LQ 图形

在这里插入图片描述

思路

很无脑的一题,没什么好说的

w,h,v = map(int,input().split())
for i in range(1,h+w+1):if 1<=i<=h:print("Q"*w)if h<i<=h+w:print("Q"*(w+v))

在这里插入图片描述

试题 D: 最多次数

在这里插入图片描述

思路

线性DP即可在O(n)复杂度解决,设dp[i]表示到第i个字母为止能切割出的最多单词,状态转移方程:如果第i个字母以及前面两个字母能够组成单词,则dp[i] = dp[i-3]+1,否则继承dp[i]=dp[i-1]

s = input()
n = len(s)
arr = [0] + [i for i in s]
def check(a,b,c):if a+b+c in ['lqb','lbq','qlb','qbl','blq','bql']:return Trueelse:return Falsedp = [0 for i in range(n+1)]
for i in range(1,n+1):if i==1 or i==2:continueif arr[i] in ['l','q','b']:if check(arr[i],arr[i-1],arr[i-2]):dp[i] = dp[i-3]+1else:dp[i] = dp[i-1]else:dp[i] = dp[i-1]
print(dp[-1])

在这里插入图片描述

试题 E: A · B Problem

在这里插入图片描述

思路

考场上没时间细想,直接用DFS枚举每一种可能,并且剪枝尽可能节约时间。

import sys
sys.setrecursionlimit(100000)def dfs(depth):global cntif depth==5:if ls[1]*ls[2] + ls[3]*ls[4] <= L:cnt+=1returnfor i in range(1,L+1):ls[depth] = iif depth==2 and ls[1]*ls[2]>L:breakif depth==3 and ls[1]*ls[2] + ls[3] >L:breakdfs(depth+1)L = int(input())
ls = [0,0,0,0,0]
cnt = 0
dfs(1)
print(cnt)

在这里插入图片描述

试题 F: 园艺

在这里插入图片描述

思路

这题乍一看是LIS的板子,但是他添加了必须等间隔这个条件,所以单纯了LIS只能找到最长上升字串的长度,且无法保证间隔。考场上没想明白怎么改,直接暴力。

n = int(input())
h = [0] + list(map(int,input().split()))
max_ = 0
for i in range(1,n):for j in range(1,n+1):idx = jtemp = 1while idx<=n:if idx+i>n:breakif h[idx+i] > h[idx]:temp += 1idx += ielse:breakmax_ = max(max_,temp)
print(max_)

在这里插入图片描述

试题 G: 书架还原

在这里插入图片描述

思路

最少操作次数意味着什么?没有多余的交换。我们可以列一些情况试一下:
任意位置的2本书混乱,只需1次对调即可复原:
在这里插入图片描述
任意位置的3本书混乱,只需2次对调即可复原:
在这里插入图片描述
同理,任意位置的k本书混乱,只需k-1次对调即可复原。
同时我们发现,这发生错放的k本书之间的互换,不涉及其他无关的书本,如果你在交换这k本书的过程中涉及到了这k本书以外的书,那就说明有多余的操作了,就不是最少操作次数了,不符合题意。
图论的角度出发,根据以上分析我们发现,如果把书看为节点,需要交换的书本之间一定是联通的,我们可以先对所有书做一个 分组,用并查集的思想,找father节点。最后统计各个集合的点的个数,修复这个集合需要的最少交换次数是点的个数减一。最后加起来就是答案。
father数组是什么?稍加分析发现其实就是题目中所给的当前每本书的编号a1,a2,...,an,他意味着:位置1现在放着编号a1,那么父节点位置a1存在着新书编号a[a1],依次类推,每遇到一个新的点,就把他加入当前集合,最后会找到编号为1的书现在的位置,也就确定了一个集合。
其他的解释看代码注释吧:

n = int(input())
father = [0] + list(map(int,input().split()))
size = [0 for i in range(n+1)] # 记录根节点对应集合的大小
vis = [0 for i in range(n+1)] # 记录每本书是否被遍历(是否已经加入到了某个集合)for i in range(1,n+1): # 每本书依次遍历if vis[i]!=0: # 如果当前书已经被加入到了某集合continue # 跳过vis[i] = 1 # 否则单开一个集合son = i # 当前子节点si = 1 # 新集合的size初始化为1for _ in range(1,n+1): # 我用循环替代嵌套,书个数n,所以最坏的情况n次循环足够找了if father[son] != i: # 找父节点,这里没有判断vis==0,因为不可能找到属于其他集合的点si += 1 # 加入到集合vis[father[son]] = 1 # 修改visson = father[son] # 更新当前子节点if father[son] == i: # 如果又找回来了i,形成闭环,这个集合就结束了breaksize[i] = si # 根节点i赋值sizenum = 0
for x in size:  # 遍历每个节点if x == 0:continue if x == 1:continue # size==1说明这本书单独为一个集合,说明本来就处于正确的位置上num = num + x-1 # 对于x本书,需要替换x-1次
print(num) # 打印总的次数

在这里插入图片描述

试题 H: 异或和

在这里插入图片描述

思路

应该是用异或的性质,但是没时间了,直接暴力求解。

n = int(input())
ls = [0] + list(map(int,input().split()))
ans = 0
for i in range(1,n+1):for j in range(i+1,n+1):ans += (ls[i]^ls[j])*(j-i)
print(ans)

在这里插入图片描述

总结

用洛谷估分大概71分,整体上看这次省赛比较简单,相比于去年难度要小很多,后面继续加油。

相关文章:

【蓝桥杯】2025省赛PythonB组复盘

前言 昨天蓝桥杯python省赛B组比完&#xff0c;今天在洛谷上估了下分&#xff0c;省一没有意外的话应该是稳了。这篇博文是对省赛试题的复盘&#xff0c;所给代码是省赛提交的代码。PB省赛洛谷题单 试题 A: 攻击次数 思路 这题目前有歧义&#xff0c;一个回合到底是只有一个…...

深入解析区块链技术:原理、应用与未来展望

1 区块链技术原理 1.1 基本概念 区块链本质上是一个分布式账本&#xff0c;它由一系列按照时间顺序排列的数据块组成&#xff0c;每个数据块包含了一定时间内的交易信息。这些数据块通过密码学技术相互链接&#xff0c;形成一个不可篡改的链条。其核心特点包括去中心化、不可篡…...

Linux进程替换与自定义shell详解

引言 进程替换和shell编程是Linux系统中极其重要的概念&#xff0c;它们不仅是系统内部工作的基础机制&#xff0c;也是系统管理员和开发者必备的技能。本文将深入探讨Linux中的进程替换原理、系统调用实现以及如何创建自定义shell&#xff0c;帮助你全面理解这些重要概念并掌…...

【数据结构_4下篇】链表

一、链表的概念 链表&#xff0c;不要求在连续的内存空间&#xff0c;链表是一个离散的结构。 链表的元素和元素之间&#xff0c;内存是不连续的&#xff0c;而且这些元素的空间之间也没有什么规律&#xff1a; 1.顺序上没有规律 2.内存空间上也没有规律 *如何知道链表中包…...

Mybatis的简单介绍

文章目录 MyBatis 简介 1. MyBatis 核心特点2. MyBatis 核心组件3. MyBatis 基本使用示例(1) 依赖引入&#xff08;Maven&#xff09;(2) 定义 Mapper 接口(3) 定义实体类(4) 在 Service 层调用 4. MyBatis 与 JPA/Hibernate 对比 MyBatis 简介 MyBatis 是一款优秀的 持久层框…...

JavaScript 性能优化实战:深入探讨 JavaScript 性能瓶颈,分享优化技巧与最佳实践

在当今 Web 应用日益复杂的时代&#xff0c;JavaScript 性能对于用户体验起着决定性作用。缓慢的脚本执行会导致页面加载延迟、交互卡顿&#xff0c;严重影响用户留存率。本文将深入剖析 JavaScript 性能瓶颈&#xff0c;并分享一系列实用的优化技巧与最佳实践&#xff0c;助你…...

1g内存电脑sqlite能支持多少并发

1. SQLite的并发机制 写操作&#xff1a;默认使用串行锁&#xff0c;同一时间仅允许一个写操作&#xff08;其他写/读需等待&#xff09;。读操作&#xff1a;支持多并发读取&#xff0c;但受内存、磁盘I/O和配置限制。 2. 关键限制因素 &#xff08;1&#xff09;内存资源 …...

jetpack之jetpack的概括和其中组件的简单使用

注意⚠&#xff1a;此篇文章由deepseek大力支持&#xff01;&#xff01;&#xff01;(╹ڡ╹ ) 主要是对不知道学什么&#xff0c;对各个组件一头雾水的jetpack新手准备的文章 不知道jetpack学什么&#xff0c;就看这篇文章&#xff01;&#xff01; 1. DataBinding&#xff…...

音视频 五 看书的笔记 MediaCodec

MediaCodec 用于访问底层媒体编解码器框架&#xff0c;编解码组件。通常与MediaExtractor(解封装,例如Mp4文件分解成 video和audio)、MediaSync、MediaMuxer(封装 例如音视频合成Mp4文件)、MediaCrypto、Image(cameraX 回调的ImageReader对象可以获取到Image帧图像,可转换成YU…...

物联网|无人自助台球厅源码|哪些框架支持多设备连接?

在无人自助台球厅的智能化管理中&#xff0c;物联网&#xff08;IoT&#xff09;技术是核心支撑。如何实现不同设备&#xff08;如智能门锁、环境传感器、支付终端、灯光控制系统等&#xff09;的高效连接与协同工作&#xff0c;是系统开发的关键挑战。本文将带大家探讨支持多设…...

Python中NumPy的统计运算

在数据分析和科学计算领域&#xff0c;Python凭借其丰富的库生态系统成为首选工具之一&#xff0c;而NumPy作为Python数值计算的核心库&#xff0c;凭借其高效的数组操作和强大的统计运算功能&#xff0c;广泛应用于机器学习、信号处理、统计分析等场景。本文将系统介绍NumPy在…...

uniapp实现H5页面麦克风权限获取与录音功能

1.权限配置 在uni-app开发H5页面时&#xff0c;需要在manifest.json文件中添加录音权限的配置。具体如下&#xff1a; {"h5": {"permissions": {"scope.record": {"desc": "请授权使用录音功能"}}} }这段配置代码是用于向…...

两个树莓派如何通过wifi direct传输视频并显示

这里写自定义目录标题 在两台设备上安装必要软件Wi-Fi Direct接收端IP&#xff08;自动发现或静态设置&#xff09;设置摄像头参数显示初始化网络设置 系统架构概述 发送端树莓派&#xff1a;捕获视频&#xff08;摄像头或视频文件&#xff09;→ 编码 → 通过Wi-Fi Direct传输…...

ubuntu 系统安装Mysql

安装 mysql sudo apt update sudo apt install mysql-server 启动服务 sudo systemctl start mysql 设置为开机自启 sudo systemctl enable mysql 查看服务状态 &#xff08;看到类似“active (running)”的状态信息代表成功&#xff09; sudo systemctl status mysql …...

selenium快速入门

一、操作浏览器 from selenium import webdriver from selenium.webdriver.chrome.options import Options from selenium.webdriver.chrome.service import Service from selenium.webdriver.common.by import By# 设置选项 q1 Options() q1.add_argument("--no-sandbo…...

Redis:线程模型

单线程模型 Redis 自诞生以来&#xff0c;一直以高性能著称。很多人好奇&#xff0c;Redis 为什么早期采用单线程模型&#xff0c;它真的比多线程还快吗&#xff1f; 其实&#xff0c;Redis 的“快”并不在于并发线程&#xff0c;而在于其整体架构设计极致简单高效&#xff0c;…...

Transformer模型解析与实例:搭建一个自己的预测语言模型

目录 1. 前言 2. Transformer 的核心结构 2.1 编码器&#xff08;Encoder&#xff09; 2.2 解码器&#xff08;Decoder&#xff09; 2.3 位置编码&#xff08;Positional Encoding&#xff09; 3. 使用 PyTorch 构建 Transformer 3.1 导入所需的模块&#xff1a; 3.2 定…...

Java常用安全编码的规范整理及工具

对Java安全编码的主要规范及要求的一些整理&#xff1a; 一、输入验证与数据校验 ‌外部输入校验‌ 对所有外部输入&#xff08;如用户输入、文件、网络数据&#xff09;进行合法性校验&#xff0c;采用白名单机制限制输入内容范围 ‌。校验前对输入数据做归一化处理&#xff…...

重返JAVA之路——面向对象

目录 面向对象 1.什么是面向对象&#xff1f; 2.面向对象的特点有哪些&#xff1f; 3.什么是对象&#xff1f; 4.什么是类&#xff1f; 5.什么是构造方法? 6.构造方法的特性有哪些&#xff1f; 封装 1.什么是封装&#xff1f; 2.封装有哪些特点&#xff1f; 数据隐…...

Java设计模式全解析(共 23 种)

一、设计模式全解&#xff1a; Java 中的设计模式是为了解决在软件开发中常见问题的一些“最佳实践”总结。设计模式分为三大类&#xff0c;共 23 种经典模式&#xff1a; 1. 创建型模式&#xff08;5 种&#xff09; 用于对象的创建&#xff0c;解决对象实例化过程中的问题。…...

Python10天突击--Day 2: 实现观察者模式

以下是 Python 实现观察者模式的完整方案&#xff0c;包含同步/异步支持、类型注解、线程安全等特性&#xff1a; 1. 经典观察者模式实现 from abc import ABC, abstractmethod from typing import List, Anyclass Observer(ABC):"""观察者抽象基类""…...

springboot框架集成websocket依赖实现物联网设备、前端网页实时通信!

需求&#xff1a; 最近在对接一个物联网里设备&#xff0c;他的通信方式是 websocket 。所以我需要在 springboot框架中集成websocket 依赖&#xff0c;从而实现与设备实时通信&#xff01; 框架&#xff1a;springboot2.7 java版本&#xff1a;java8 好了&#xff0c;还是直接…...

【玩泰山派】5、点灯,驱动led-(2)ubuntu18.04 升级python3.6到python3.7,安装pip3

文章目录 前言升级python3.71、安装 software-properties-common 包2、添加 deadsnakes PPA 源3、安装 Python 3.71. 安装 Python 3.72. 安装 Python 3.7 的开发包和虚拟环境支持&#xff08;可选但推荐&#xff09;3. 设置 Python 3.7 为默认版本4. 验证 Python 版本注意事项 …...

ES6学习03-字符串扩展(unicode、for...of、字符串模板)和新方法()

一、字符串扩展 1. eg: 2.for...of eg: 3. eg: 二。字符串新增方法 1. 2. 3. 4. 5....

c++中的this

在 C 中&#xff0c;this 是一个指向当前对象实例的指针&#xff0c;它隐式地存在于类的非静态成员函数中。以下是 this 的详细用法和常见场景&#xff1a; 1. 常见场景 明确成员归属&#xff1a;当成员变量与局部变量同名时&#xff0c;用 this-> 显式访问成员。当成员变量…...

目前状况下,计算机和人工智能是什么关系?

目录 一、计算机和人工智能的关系 &#xff08;一&#xff09;从学科发展角度看 计算机是基础 人工智能是计算机的延伸和拓展 &#xff08;二&#xff09;从技术应用角度看 二、计算机系学生对人工智能的了解程度 &#xff08;一&#xff09;基础层面的了解 必备知识 …...

Flutter 2025 Roadmap

2025 这个路线图是有抱负的。它主要代表了我们这些在谷歌工作的人收集的内容。到目前为止&#xff0c;非Google贡献者的数量超过了谷歌雇佣的贡献者&#xff0c;所以这并不是一个详尽的列表&#xff0c;列出了我们希望今年Flutter能够出现的所有令人兴奋的新事物&#xff01;在…...

[数据结构]排序 --2

目录 8、快速排序 8.1、Hoare版 8.2、挖坑法 8.3、前后指针法 9、快速排序优化 9.1、三数取中法 9.2、采用插入排序 10、快速排序非递归 11、归并排序 12、归并排序非递归 13、排序类算法总结 14、计数排序 15、其他排序 15.1、基数排序 15.2、桶排序 8、快速排…...

第16届蓝桥杯c++省赛c组个人题解

偷偷吐槽&#xff1a; c组没人写题解吗&#xff0c;找不到题解啊 P12162 [蓝桥杯 2025 省 C/研究生组] 数位倍数 题目背景 本站蓝桥杯 2025 省赛测试数据均为洛谷自造&#xff0c;与官方数据可能存在差异&#xff0c;仅供学习参考。 题目描述 请问在 1 至 202504&#xff…...

记一次InternVL3- 2B 8B的部署测验日志

1、模型下载魔搭社区 2、运行环境&#xff1a; 1、硬件 RTX 3090*1 云主机[普通性能] 8核15G 200G 免费 32 Mbps付费68Mbps ubuntu22.04 cuda12.4 2、软件&#xff1a; flash_attn&#xff08;好像不用装 忘记了&#xff09; numpy Pillow10.3.0 Requests2.31.0 transfo…...