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

Leetcode 2911. Minimum Changes to Make K Semi-palindromes

  • Leetcode 2911. Minimum Changes to Make K Semi-palindromes
    • 1. 解题思路
    • 2. 代码实现
  • 题目链接:2911. Minimum Changes to Make K Semi-palindromes

1. 解题思路

这一题属实也是把我坑惨了……

坦率地说,这道题本身并没有啥难度,但是坑爹的是题目表述简直有毒,有两个细节题目里面压根没提,一个是我从中文版本的题目当中发现的,另一个则是我根据失败的样例当中反推出来的,这简直有毒……

这道题本身思路上还是挺直接的,就是一个动态规划的题目,考虑每一种切分的方式,然后考察其中最小的变化次数即可。

然后对于每一个切分得到的子串,我们要求其变化所需的最小变化次数,我们只需要找到其所有对长度 l l l整除的 d d d,然后切分semi子串,再考察其中每一种分法下所需的变化次数之和,最后取最小值即可。

因此,我们就将上述题目拆分完成了,后续只要对其实现一下即可,测试发现是可以在有效时间内完成所有测试样例的。

但是,这里但是就来了,题目中遗漏了两个非常非常重要的说明,把我给坑惨了!!!

首先,这里semi-palindrome的定义事实上要求将其使用d进行切分后,每一个子串都得是回文,其次,题中也没有具体说,但是实际测试发现,这里对子串的切分要求每一个子串长度至少为2

这简直就是简直了!!!

到底谁出的题目啊,只能说,出来挨打!!!

2. 代码实现

给出python代码实现如下:

class Solution:def minimumChanges(self, s: str, k: int) -> int:n = len(s)@lru_cache(None)def count(sub):cnt = 0n = len(sub)for i in range(n//2):if sub[i] != sub[n-1-i]:cnt += 1return cnt@lru_cache(None)def count_change(s):if s == s[::-1]:return 0n = len(s)ans = count(s)for d in range(len(s)//2, 0, -1):if n % d != 0:continuek = n // dcnt = 0for i in range(d):sub = "".join([s[i+j*d] for j in range(k)])cnt += count(sub)ans = min(ans, cnt)return ans@lru_cache(None)def dp(idx, k):if idx+2*k > n:return math.infelif k == 1:return count_change(s[idx:])return min(count_change(s[idx:j]) + dp(j, k-1) for j in range(idx+2, n))ans = dp(0, k)return ans   

提交代码评测得到:耗时5650ms,占用内存71.8MB。

相关文章:

Leetcode 2911. Minimum Changes to Make K Semi-palindromes

Leetcode 2911. Minimum Changes to Make K Semi-palindromes 1. 解题思路2. 代码实现 题目链接:2911. Minimum Changes to Make K Semi-palindromes 1. 解题思路 这一题属实也是把我坑惨了…… 坦率地说,这道题本身并没有啥难度,但是坑爹…...

Node学习笔记之包管理工具

一、概念介绍 1.1 包是什么 『包』英文单词是package ,代表了一组特定功能的源码集合 1.2 包管理工具 管理『包』的应用软件,可以对「包」进行 下载安装 , 更新 , 删除 , 上传 等操作 借助包管理工具,可…...

分发糖果[困难]

优质博文:IT-BLOG-CN 一、题目 n个孩子站成一排。给你一个整数数组ratings表示每个孩子的评分。你需要按照以下要求,给这些孩子分发糖果: 【1】每个孩子至少分配到1个糖果。 【2】相邻两个孩子评分更高的孩子会获得更多的糖果。 请你给每个孩…...

Java验证邮箱格式是否正确的正则表达式

Java验证邮箱格式是否正确的正则表达式 import java.util.regex.Pattern;public class EmailUtil {final static Pattern partern Pattern.compile("[a-zA-Z0-9][\\.]{0,1}[a-zA-Z0-9][a-zA-Z0-9]\\.[a-zA-Z]");/*** 验证输入的邮箱格式是否符合* param email* ret…...

快速排序原理JAVA和Scala实现-函数式编程的简洁演示

快速排序原理JAVA和Scala实现-函数式编程的简洁演示 目录 快速排序原理JAVA和Scala实现-函数式编程的简洁演示 C语言快速排序实现 Java 快速排序实现 Scala 快速排序实现 本文章向大家介绍快速排序原理JAVA和Scala实现-函数式编程的简洁演示,主要内容包括C语言…...

如何在linux服务器上安装Anaconda与pytorch

如何在linux服务器上安装Anaconda与pytorch 1,安装anaconda1.1 下载anaconda安装包1.2 安装anaconda1.3 设计环境变量1.4 安装完成验证 2 Anaconda安装pytorch2.1 创建虚拟环境2.2 查看现存环境2.3 激活环境2.4 选择合适的pytorch版本下载2.5 检测是否安装成功&…...

FPGA设计FIR滤波器低通滤波器,代码及视频

名称:FIR滤波器低通滤波器 软件:Quartus 语言:Verilog/VHDL 本资源含有verilog及VHDL两种语言设计的工程,每个工程均可实现以下FIR滤波器的功能。 代码功能: 设计一个8阶FIR滤波器(低通滤波器&#xff…...

【数据结构】排序--快速排序

目录 一 概念 二 快速排序的实现 1. hoare版本 (1)代码实现 (2)单趟排序图解 (3) 递归实现图解 (4)细节控制 (5)时间复杂度 (6)三数取中优化 2 挖坑法 (1)代码实现 (2)单趟图解 3 前后指针法 (1) 代码实现 (2) 单趟图解 ​4 优化子区间 5 非递归快速排序 …...

【试题040】多个逻辑或例题2

1.题目:设int n0;,执行表达式n ||(n-1) ||(n0)||(n1)||(n2)后n的值是 ? 2.代码解析: 逻辑或 || 运算符是一个短路运算符,它从左到右依次计算表达式,如果遇到一个为真(非零)的值&am…...

自然语言处理---Self Attention自注意力机制

Self-attention介绍 Self-attention是一种特殊的attention,是应用在transformer中最重要的结构之一。attention机制,它能够帮助找到子序列和全局的attention的关系,也就是找到权重值wi。Self-attention相对于attention的变化,其实…...

推荐收藏系列!2万字图解Hadoop

今天我用图解的方式讲解pandas的用法,内容较长建议收藏,梳理不易,点赞支持。 学习 Python 编程,给我的经验就是:技术要学会分享、交流,不建议闭门造车。一个人可能走的很快、但一堆人可以走的更远。如果你…...

Python高级篇(08):生成器

一、生成器定义和作用 定义:Python中,一边循环一边计算的机制,生成器对象也是迭代器对象,支持for循环、next()方法…等。作用:循环的过程中不断推算出后续的元素,这样就不必创建完整的list,从而…...

力扣100114. 元素和最小的山形三元组 II(中等)

题目描述&#xff1a; 给你一个下标从 0 开始的整数数组 nums 。 如果下标三元组 (i, j, k) 满足下述全部条件&#xff0c;则认为它是一个 山形三元组 &#xff1a; i < j < knums[i] < nums[j] 且 nums[k] < nums[j] 请你找出 nums 中 元素和最小 的山形三元组…...

LuatOS-SOC接口文档(air780E)--lcdseg - 段式lcd

常量 常量 类型 解释 lcdseg.BIAS_STATIC number 没偏置电压(bias) lcdseg.BIAS_ONEHALF number 1/2偏置电压(bias) lcdseg.BIAS_ONETHIRD number 1/3偏置电压(bias) lcdseg.BIAS_ONEFOURTH number 1/4偏置电压(bias) lcdseg.DUTY_STATIC number 100%占空比(d…...

实现图像处理和分析的关键技术

在计算机视觉中&#xff0c;我们可以利用摄像头捕捉到的图像来进行各种分析和处理。以下是一些常见的计算机视觉任务&#xff1a; 对象检测&#xff1a;识别图像中的特定对象并标注其位置。人脸识别&#xff1a;识别和验证人脸身份。姿态估计&#xff1a;估计人体的姿态和动作…...

【C++学习笔记】内联函数

1. 概念 以inline修饰的函数叫做内联函数&#xff0c;编译时C编译器会在调用内联函数的地方展开&#xff0c;没有函数调 用建立栈帧的开销&#xff0c;内联函数提升程序运行的效率。 如果在上述函数前增加inline关键字将其改成内联函数&#xff0c;在编译期间编译器会用函数…...

macOS Sonoma 14.1RC(23B73)发布

黑果魏叔10 月 18 日消息&#xff0c;苹果今日向 Mac 电脑用户推送了 macOS 14.1 RC更新&#xff08;内部版本号&#xff1a;23B73&#xff09;&#xff0c;本次更新距离上次发布隔了 7 天。 macOS Sonoma 14.1RC&#xff08;23B73&#xff09;的更新内容主要包括以下方面&…...

数据结构数组 Array 手写实现,扩容原理

数组数据结构 数组&#xff08;Array&#xff09;是一种线性表数据结构。它用一组连续的内存空间&#xff0c;来存储一组具有相同类型数据的集合。 数组的特点&#xff1a; 数组是相同数据类型的元素集合&#xff08;int 不能存放 double&#xff09;数组中各元素的存储是有先…...

工作中几个问题的思考

对于需要并行多公司并行处理的任务&#xff0c;方案是什么&#xff1f; 多线程、并行流、并发库&#xff08;ExecutorService、Futrue、Callable&#xff09;&#xff0c;分布式计算&#xff08;1&#xff09;按照公司ID分片 &#xff08;2&#xff09;按照业务类型分片 处理…...

Jmeter的性能测试

性能测试的概念 定义&#xff1a;软件的性能是软件的一种非功能特性&#xff0c;它关注的不是软件是否能够完成特定的功能&#xff0c;而是在完成该功能时展示出来的及时性。 由定义可知性能关注的是软件的非功能特性&#xff0c;所以一般来说性能测试介入的时机是在功能测试…...

Dify二次开发实战:从环境搭建到CI/CD全链路解析

1. 环境准备&#xff1a;搭建Dify二次开发的基础设施 第一次接触Dify二次开发时&#xff0c;我被它复杂的依赖关系搞得手忙脚乱。经过三个项目的实战积累&#xff0c;我总结出一套最稳定的环境配置方案&#xff0c;让你少走弯路。 开发Dify需要同时处理Python和Node.js两个生态…...

linux 安装 人大金仓数据库

1.安装人大金仓 下载链接 KingbaseES_V008R006C009B0014_Lin64_install.iso 2.上传文件到 /home/soft/ cd /home mkdir soft cd /soft3.创建kingbase用户作为KingbaseES安装用户。 # 安装依赖库 yum install -y libaio-devel gcc glibc make # 创建用户组 groupadd kingbase …...

别再只用数组了!用MATLAB结构体(struct)管理实验数据的5个实战技巧

别再只用数组了&#xff01;用MATLAB结构体&#xff08;struct&#xff09;管理实验数据的5个实战技巧 在实验室里泡了三年后&#xff0c;我终于受够了那些散落在脚本各处的data1、data2变量&#xff0c;以及需要反复查阅注释才能理解的复杂元胞数组。直到有天看到隔壁工位的博…...

【AI Agent 从入门到精通】第七章:AI Agent 记忆系统:从短期到长期记忆的设计与实现

📌 前置说明:本系列共 8 章,建议按顺序阅读。 📖 系列导航: 第一章:AI Agent 是什么?一文讲清楚核心概念与架构 第二章:AI Agent 的技术原理:LLM + 规划 + 记忆 + 工具 第三章:主流 AI Agent 框架对比:LangChain、AutoGPT、AutoGen、LlamaIndex 第四章:动手实现你…...

CSS 网格元素:构建现代网页布局的利器

CSS 网格元素:构建现代网页布局的利器 概述 随着互联网技术的飞速发展,网页设计已经成为前端开发中不可或缺的一部分。CSS 网格元素(Grid)的出现,为现代网页布局提供了更加灵活和高效的方法。本文将详细介绍 CSS 网格元素的概念、用法以及在实际项目中的应用。 CSS 网格…...

be-a-hacker工具开发实践:从需求分析到代码实现的全流程

be-a-hacker工具开发实践&#xff1a;从需求分析到代码实现的全流程 【免费下载链接】be-a-hacker roadmap for a self-taught hacker 项目地址: https://gitcode.com/gh_mirrors/be/be-a-hacker GitHub加速计划&#xff08;be-a-hacker&#xff09;是一个面向自学黑客的…...

从相机到屏幕:深入解析图形渲染管线中的MVP与视口变换

1. 从三维世界到二维屏幕的魔法之旅 想象一下你正在玩一款3D游戏&#xff0c;角色在森林中奔跑。树木、岩石、阳光这些三维物体是如何变成你屏幕上那些二维像素的呢&#xff1f;这就是图形渲染管线要解决的核心问题。整个过程就像用相机拍摄照片&#xff1a;你需要调整相机位置…...

2026论文查AI率渠道降AI工具实测指南「收藏备用」

近年毕业的同学一定要留意&#xff1a;学位法已明确将不当使用人工智能写作纳入学术不端范畴。现在的毕业论文审核&#xff0c;除了传统重复率要求&#xff0c;还必须附上AIGC检测报告&#xff0c;要是AI率超标&#xff0c;轻则被要求退回重改&#xff0c;严重的还会影响学位授…...

告别Spyder导入报错:Anaconda环境中PyTorch安装后的终极调试指南

告别Spyder导入报错&#xff1a;Anaconda环境中PyTorch安装后的终极调试指南 在数据科学和深度学习的世界里&#xff0c;PyTorch无疑是当前最受欢迎的框架之一。然而&#xff0c;许多初学者在成功安装PyTorch后&#xff0c;却常常在最后一步——在Spyder或Jupyter Notebook中导…...

终极指南:如何用Testsigma在30分钟内搭建企业级自动化测试平台

终极指南&#xff1a;如何用Testsigma在30分钟内搭建企业级自动化测试平台 【免费下载链接】testsigma Testsigma is an agentic test automation platform powered by AI-coworkers that work alongside QA teams to simplify testing, accelerate releases and improve quali…...