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

蓝桥杯思维训练(五)

文章目录

  • 子集II
  • 1191.K次串联后最大子数组之和

子集II

子集II

在这里插入图片描述

在这里插入图片描述

思路分析: 求解子集的问题的关键就是,通过递归与回溯,我们就是得确定以某个元素开始的子集,对于这个题目来说,比较麻烦的一点就是,存在重复的元素,这样如果不增加一个判断的话,会导致我们的结果存在重复的元素

如何消除重复的情况?

nums.sort()  # 排序,方便去重
# 在这个for 训练里面,我们是用于选择子集的开始的元素的,只要我们开始的元素没有和前一个元素相同,那么就可以进行递归增加元素
if i > start and nums[i] == nums[i-1]:continue

整体的代码中,我们使用ans 来记录全部的子集,path来记录当前的元素的情况

class Solution:def subsetsWithDup(self, nums: List[int]) -> List[List[int]]:nums.sort()  # 排序,方便去重ans = []path = []def backtrack(start):ans.append(path[:])  # 添加当前子集到结果中for i in range(start, len(nums)):# 跳过重复元素if i > start and nums[i] == nums[i-1]:continuepath.append(nums[i])  # 选择当前元素backtrack(i + 1)  # 递归path.pop()  # 撤销选择backtrack(0)return ans

1191.K次串联后最大子数组之和

1191.K次串联后最大子数组之和

在这里插入图片描述
在这里插入图片描述

思路分析:由于k和arr数组长度都很长,所以不可能全部拼接起来,所以说就根本不用全部拼接起来
规律:当k=1的时候,就是正常算,如果K>=2的时候,我们可以先拼接两个进行正常运算,如果max(dp) 小于等于0,则返回0,然后我们思考这两段之间能否插入剩余的段,所以我们计算sum(arr),如果sum(arr)>0,就可以拼接在两段之间,否则就直接返回两段的情况,记得要取模再返回

class Solution:def kConcatenationMaxSum(self, arr: List[int], k: int) -> int:# 肯定是不能直接拼接上去再dp的不然,o(n)的时间复杂度也到了10^10,所以还是在之前的数组arr操作#n = len(arr)ans = 0if k == 1:dp = [0]*ndp[0] = arr[0]for i in range(1,n):dp[i] = max(dp[i-1]+arr[i],arr[i])# 判断ans,如果小于等于0,就返回0,否则就是取模返回ans = max(dp)return ans%(10**9+7) if ans >0 else 0else:dp = [0]*(2*n)dp[0] = arr[0]# 拼接nums = arr + arrfor i in range(1,2*n):dp[i] = max(dp[i-1]+nums[i],nums[i])# 查看最大值ans = max(dp)# 小于等于0就返回if ans<=0:return 0sumarr = sum(arr)# 看看能否插入其中if sumarr>0:return (ans+(k-2)*sumarr)%(10**9+7)else:return ans%(10**9+7)
http://www.lryc.cn/news/532935.html

相关文章:

  • I.MX6ULL 中断介绍下
  • Elasticsearch 生产集群部署终极方案
  • Python用langchain、OpenAI大语言模型LLM情感分析苹果股票新闻数据及提示工程优化应用...
  • 【正点原子K210连载】第六十七章 音频FFT实验 摘自【正点原子】DNK210使用指南-CanMV版指南
  • Centos Ollama + Deepseek-r1+Chatbox运行环境搭建
  • ReactNative进阶(五十九):存量 react-native 项目适配 HarmonyOS NEXT
  • go并发和并行
  • 一种解决SoC总线功能验证完备性的技术
  • Web3 与区块链:开启透明、安全的网络新时代
  • c#中Thread.Join()方法的经典示例
  • 深入了解越权漏洞:概念、危害与防范
  • MySQL 数据库编程-C++
  • dl学习笔记(9):pytorch数据处理的完整流程
  • wps中的vba开发
  • 力扣 LCR 078 合并K个升序链表
  • 【hive】记一次hiveserver内存溢出排查,线程池未正确关闭导致
  • React Native 开发 安卓项目构建工具Gradle的配置和使用
  • IntelliJ IDEA新版本的底部version control(或git)里local change窗口显示配置修改详细教程
  • MySQL三大日志——binlog、redoLog、undoLog详解
  • MCU应用踩坑笔记(ADC 中断 / 查询法)
  • 32.日常算法
  • 通过docker安装部署deepseek以及python实现
  • 批量提取word表格数据到一个excel
  • 使用 Axios 获取用户数据并渲染——个人信息设置
  • DeepSeek在FPGA/IC开发中的创新应用与未来潜力
  • 【GitLab CI/CD 实践】从 0 到 1 搭建高效自动化部署流程
  • 【DeepSeek-R1训练笔记】随手记录一些训练log
  • 【自开发工具介绍】SQLSERVER的ImpDp和ExpDp工具04
  • 「全网最细 + 实战源码案例」设计模式——策略模式
  • [MoeCTF 2022]baby_file