邯郸一堆网络科技/搜易网优化的效果如何

邯郸一堆网络科技,搜易网优化的效果如何,怎样做淘宝客网站,wordpress注册字段【LetMeFly】132.分割回文串 II:动态规划 力扣题目链接:https://leetcode.cn/problems/palindrome-partitioning-ii/ 给你一个字符串 s,请你将 s 分割成一些子串,使每个子串都是回文串。 返回符合要求的 最少分割次数 。 示例 …

【LetMeFly】132.分割回文串 II:动态规划

力扣题目链接:https://leetcode.cn/problems/palindrome-partitioning-ii/

给你一个字符串 s,请你将 s 分割成一些子串,使每个子串都是回文串。

返回符合要求的 最少分割次数

 

示例 1:

输入:s = "aab"
输出:1
解释:只需一次分割就可将 s 分割成 ["aa","b"] 这样两个回文子串。

示例 2:

输入:s = "a"
输出:0

示例 3:

输入:s = "ab"
输出:1

 

提示:

  • 1 <= s.length <= 2000
  • s 仅由小写英文字母组成

解题方法:动态规划

整个过程分为两步:预处理 和 动态规划

动态规划:

使用数组 d p dp dp,其中 d p [ i ] dp[i] dp[i]代表使得子字符串 0... i 0...i 0...i为回文字符串组合的最小分割次数,那么 d p [ l e n ( s ) − 1 ] dp[len(s) - 1] dp[len(s)1]即为答案。

  • 如果 0... i 0...i 0...i直接为回文字符串,那么分割次数为0。

  • 否则,对于 j ∈ 0... i − 1 j\in 0...i-1 j0...i1,如果 j + 1.. i j + 1..i j+1..i是回文字符串,那么有 d p [ i ] = m i n ( d p [ j ] + 1 ) dp[i] = min(dp[j] + 1) dp[i]=min(dp[j]+1)

预处理:

有没有什么办法 O ( 1 ) O(1) O(1)时间内快速判断下标从 i i i j j j的子字符串是否为回文字符串?有,我们可以先使用 O ( n 2 ) O(n^2) O(n2)复杂度的时间预处理。使用 i s O k [ i ] [ j ] isOk[i][j] isOk[i][j]表示子字符串 i . . . j i...j i...j是否为回文字符串:

  • 如果子字符串为空或者长度为1,则是回文字符串( i ≥ j i \geq j ij)
  • 否则:是回文字符串当且仅当 s [ i ] = = s [ j ] AND  i s O k [ i + 1 ] [ j − 1 ] s[i] == s[j] \text{ AND }isOk[i + 1][j - 1] s[i]==s[j] AND isOk[i+1][j1]

时空复杂度分析

  • 时间复杂度 O ( n 2 ) O(n^2) O(n2),预处理和动态规划的时间复杂度都是 O ( n 2 ) O(n^2) O(n2)。其中 n = l e n ( s ) n = len(s) n=len(s)
  • 空间复杂度 O ( n 2 ) O(n^2) O(n2)

AC代码

C++
/** @Author: LetMeFly* @Date: 2025-03-02 12:02:45* @LastEditors: LetMeFly.xyz* @LastEditTime: 2025-03-02 12:26:06*/
class Solution {
public:int minCut(string s) {vector<vector<bool>> isOk(s.size(), vector<bool>(s.size(), true));for (int i = s.size() - 1; i >= 0; i--) {for (int j = i + 1; j < s.size(); j++) {isOk[i][j] = s[i] == s[j] && isOk[i + 1][j - 1];}}vector<int> dp(s.size(), 1000000);for (int i = 0; i < s.size(); i++) {if (isOk[0][i]) {dp[i] = 0;continue;}for (int j = 0; j < i; j++) {if (isOk[j + 1][i]) {dp[i] = min(dp[i], dp[j] + 1);}}}return dp.back();}
};
Python
'''
Author: LetMeFly
Date: 2025-03-02 12:26:57
LastEditors: LetMeFly.xyz
LastEditTime: 2025-03-02 12:33:40
'''
class Solution:def minCut(self, s: str) -> int:isOk = [[True] * len(s) for _ in range(len(s))]for i in range(len(s) - 1, -1, -1):for j in range(i + 1, len(s)):isOk[i][j] = s[i] == s[j] and isOk[i + 1][j - 1]dp = [100000] * len(s)for i in range(len(s)):if isOk[0][i]:dp[i] = 0continuefor j in range(i):if isOk[j + 1][i]:dp[i] = min(dp[i], dp[j] + 1)return dp[-1]
Java
/** @Author: LetMeFly* @Date: 2025-03-02 12:34:31* @LastEditors: LetMeFly.xyz* @LastEditTime: 2025-03-02 12:38:17*/
class Solution {public int minCut(String s) {boolean[][] isOk = new boolean[s.length()][s.length()];for (int i = 0; i < s.length(); i++) {for (int j = 0; j < s.length(); j++) {isOk[i][j] = true;}}for (int i = s.length() - 1; i >= 0; i--) {for (int j = i + 1; j < s.length(); j++) {isOk[i][j] = s.charAt(i) == s.charAt(j) && isOk[i + 1][j - 1];}}int[] dp = new int[s.length()];for (int i = 0; i < s.length(); i++) {dp[i] = 100000;}for (int i = 0; i < s.length(); i++) {if (isOk[0][i]) {dp[i] = 0;continue;}for (int j = 0; j < i; j++) {if (isOk[j + 1][i]) {dp[i] = Math.min(dp[i], dp[j] + 1);}}}return dp[dp.length - 1];}
}
Go
/** @Author: LetMeFly* @Date: 2025-03-02 12:39:13* @LastEditors: LetMeFly.xyz* @LastEditTime: 2025-03-02 12:43:12*/
package mainfunc minCut(s string) int {isOk := make([][]bool, len(s))for i, _ := range isOk {isOk[i] = make([]bool, len(s))for j, _ := range isOk[i] {isOk[i][j] = true}}for i := len(s) - 1; i >= 0; i-- {for j := i + 1; j < len(s); j++ {isOk[i][j] = s[i] == s[j] && isOk[i + 1][j - 1]}}dp := make([]int, len(s))for i, _ := range dp {dp[i] = 100000}for i := 0; i < len(dp); i++ {if isOk[0][i] {dp[i] = 0continue}for j := 0; j < i; j++ {if isOk[j + 1][i] {dp[i] = min(dp[i], dp[j] + 1)}}}return dp[len(dp) - 1]
}

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

千篇源码题解已开源

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

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

相关文章

C++蓝桥杯基础篇(六)

片头 嗨~小伙伴们&#xff0c;大家好&#xff01;今天我们来一起学习蓝桥杯基础篇&#xff08;六&#xff09;&#xff0c;练习相关的数组习题&#xff0c;准备好了吗&#xff1f;咱们开始咯&#xff01; 第1题 数组的左方区域 这道题&#xff0c;实质上是找规律&#xff0c;…

git -学习笔记

目录 基本操作语法 设置用户和邮箱 版本回退 工作区和暂存区 撤销修改 删除与恢复 一工作区删除了&#xff0c;但是暂存区没删除 二工作区误删了&#xff0c;暂存区还有 github-Git 连接 报错解决-push远程仓库被拒绝 远程库 分支 分支冲突 储藏分支 回到当前分…

Windows本地Docker+Open-WebUI部署DeepSeek

最近想在自己的电脑本地部署一下DeepSeek试试&#xff0c;由于不希望污染电脑的Windows环境&#xff0c;所以在wsl中安装了ollama&#xff0c;使用ollama拉取DeepSeek模型。然后在Windows中安装了Docker Desktop&#xff0c;在Docker中部署了Open-WebUI&#xff0c;最后再在Ope…

力扣785. 判断二分图

力扣785. 判断二分图 题目 题目解析及思路 题目要求将所有节点分成两部分&#xff0c;每条边的两个端点都必须在不同集合中 二分图&#xff1a;BFS/DFS/并查集 因为图不一定联通&#xff0c;所以枚举所有点都做bfs(如果没联通的话) 代码 class Solution { public:bool is…

springboot之集成Elasticsearch

目录 二、Elasticsearch 是什么&#xff1f;三、Elasticsearch 安装四、Springboot 集成 Elasticsearch 的方式五、创建项目集成 Elasticsearch 2.创建 Spring Initializr 项目 es &#xff08;3&#xff09;.新建实体类 User&#xff08;4&#xff09;.新建 dao 接口类 UserR…

[Lc滑动窗口_1] 长度最小的数组 | 无重复字符的最长子串 | 最大连续1的个数 III | 将 x 减到 0 的最小操作数

目录 1. 长度最小的字数组 题解 代码 ⭕2.无重复字符的最长子串 题解 代码 3.最大连续1的个数 III 题解 代码 4.将 x 减到 0 的最小操作数 题解 代码 1. 长度最小的字数组 题目链接&#xff1a;209.长度最小的字数组 题目分析: 给定一个含有 n 个 正整数 的数组…

数据集笔记:新加坡 地铁(MRT)和轻轨(LRT)票价

数据连接 data.gov.sg 2024 年 12 月 28 日起生效的新加坡地铁票价 该数据集包含 MRT 和 LRT 票价的信息&#xff0c;包括&#xff1a; 票价类型&#xff08;Fare Type&#xff09;&#xff1a;成人票、学生票、老年人票、残障人士票等。适用时间&#xff08;Applicable Tim…

【前端基础】Day 3 CSS-2

目录 1. Emmet语法 1.1 快速生成HTML结构语法 1.2 快速生成CSS样式语法 2. CSS的复合选择器 2.1 后代选择器 2.2 子选择器 2.3 并集选择器 2.4 伪类选择器 2.4.1 链接伪类选择器 2.4.2 focus伪类选择器 2.5 复合选择器总结 3. CSS的元素显示模式 3.1 什么是元素显示…

RabbitMQ操作实战

1.RabbitMQ安装 RabbitMQ Windows 安装、配置、使用 - 小白教程-腾讯云开发者社区-腾讯云下载erlang&#xff1a;http://www.erlang.org/downloads/https://cloud.tencent.com/developer/article/2192340 Windows 10安装RabbitMQ及延时消息插件rabbitmq_delayed_message_exch…

【北京迅为】itop-3568 开发板openharmony鸿蒙烧写及测试-第2章OpenHarmony v3.2-Beta4版本测试

瑞芯微RK3568芯片是一款定位中高端的通用型SOC&#xff0c;采用22nm制程工艺&#xff0c;搭载一颗四核Cortex-A55处理器和Mali G52 2EE 图形处理器。RK3568 支持4K 解码和 1080P 编码&#xff0c;支持SATA/PCIE/USB3.0 外围接口。RK3568内置独立NPU&#xff0c;可用于轻量级人工…

stm32hal库寻迹+蓝牙智能车(STM32F103C8T6)

简介: 这个小车的芯片是STM32F103C8T6&#xff0c;其他的芯片也可以照猫画虎,基本配置差不多,要注意的就是,管脚复用,管脚的特殊功能,(这点不用担心,hal库每个管脚的功能都会给你罗列,很方便的.)由于我做的比较简单,只是用到了几个简单外设.主要是由带霍尔编码器电机的车模,电机…

SQL命令详解之操作数据库

操作数据库 SQL是用于管理和操作关系型数据库的标准语言。数据库操作是SQL的核心功能之一&#xff0c;主要用于创建、修改和删除数据库对象&#xff0c;如数据库、表、视图和索引等。以下是SQL中常见的数据库操作命令及其功能简介&#xff1a; 1. 查询数据库 查询所有的数据库…

Go红队开发—编解码工具

文章目录 开启一个项目编解码工具开发Dongle包Base64编解码摩斯密码URL加解密AES加解密 MD5碰撞工具开发 开启一个项目 这作为补充内容&#xff0c;可忽略直接看下面的编解码&#xff1a; 一开始用就按照下面的步骤即可 1.创建一个文件夹&#xff0c;你自己定义名字(建议只用…

Starrocks入门(二)

1、背景&#xff1a;考虑到Starrocks入门这篇文章&#xff0c;安装的是3.0.1版本的SR&#xff0c;参考&#xff1a;Starrocks入门-CSDN博客 但是官网的文档&#xff0c;没有对应3.0.x版本的资料&#xff0c;却有3.2或者3.3或者3.4或者3.1或者2.5版本的资料&#xff0c;不要用较…

SwiftUI之状态管理全解析

文章目录 引言一、`@State`1.1 基本概念1.2 初始化与默认值1.3 注意事项二、`@Binding`2.1 基本概念2.2 初始化与使用2.3 注意事项三、`@ObservedObject`3.1 基本概念3.2 初始化与使用3.3 注意事项四、`@EnvironmentObject`4.1 基本概念4.2 初始化与使用4.3 注意事项五、`@Stat…

Redis 高可用性:如何让你的缓存一直在线,稳定运行?

&#x1f3af; 引言&#xff1a;Redis的高可用性为啥这么重要&#xff1f; 在现代高可用系统中&#xff0c;Redis 是一款不可或缺的分布式缓存与数据库系统。无论是提升访问速度&#xff0c;还是实现数据的高效持久化&#xff0c;Redis 都能轻松搞定。可是&#xff0c;当你把 …

Redis---缓存穿透,雪崩,击穿

文章目录 缓存穿透什么是缓存穿透&#xff1f;缓存穿透情况的处理流程是怎样的&#xff1f;缓存穿透的解决办法缓存无效 key布隆过滤器 缓存雪崩什么是缓存雪崩&#xff1f;缓存雪崩的解决办法 缓存击穿什么是缓存击穿&#xff1f;缓存击穿的解决办法 区别对比 在如今的开发中&…

【定昌Linux系统】部署了java程序,设置开启启动

将代码上传到相应的目录&#xff0c;并且配置了一个.sh的启动脚本文件 文件内容&#xff1a; #!/bin/bash# 指定JAR文件的路径&#xff08;如果JAR文件在当前目录&#xff0c;可以直接使用文件名&#xff09; JAR_FILE"/usr/local/java/xs_luruan_client/lib/xs_luruan_…

Minio搭建并在SpringBoot中使用完成用户头像的上传

Minio使用搭建并上传用户头像到服务器操作,学习笔记 Minio介绍 minio官网 MinIO是一个开源的分布式对象存储服务器&#xff0c;支持S3协议并且可以在多节点上实现数据的高可用和容错。它采用Go语言开发&#xff0c;拥有轻量级、高性能、易部署等特点&#xff0c;并且可以自由…

vue3中ref和reactive响应式数据、ref模板引用(组合式和选项式区别)、组件ref的使用

目录 Ⅰ.ref 1.基本用法&#xff1a;ref响应式数据 2.ref模板引用 3.ref在v-for中的模板引用 ​4.ref在组件上使用 ​5.TS中ref数据标注类型 Ⅱ.reactive 1.基本用法&#xff1a;reactive响应式数据 2.TS中reactive标注类型 Ⅲ.ref和reactive的使用场景和区别 Ⅳ.小结…