Leetcode 522. 最长特殊序列 II (判断子序列 优化)

2024-06-18 13:04

本文主要是介绍Leetcode 522. 最长特殊序列 II (判断子序列 优化),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Leetcode 522. 最长特殊序列 II

暴力枚举

根据特殊序列的定义,枚举出每个 strs[ i ] 的所有子序列,再将这个子序列与strs中的其他串比较判断
使用二进制位运算枚举一个str的所有子序列
使用双指针指向两个串的开头,同时移动判断是否是子序列

子串 定义为原字符串中任意连续的一段,
如"abcd"中的“bc”
子序列 定义为原字符串中选择某些字符所组成的新字符串,它们的相对顺序不变,不需连续
如“abcd”中的“ac”

class Solution {// 判断函数  s是否为t的子序列public boolean isSubsequence(String s, String t) {int m = s.length();int n = t.length();int ls = 0;int lt = 0;while(ls < m && lt < n){if(s.charAt(ls) == t.charAt(lt)){ls ++;}lt ++;}return ls == m;}public int findLUSlength(String[] strs) {int n = strs.length;int res = -1;for(int i = 0 ; i < n; i ++){String s = strs[i];int len = s.length();// 枚举s的每个子序列for(int k = 1; k < (1 << len); k ++){StringBuffer sb = new StringBuffer("");for(int j = 0; j < len; j ++){if((k & (1 << j)) != 0){ // 不能写成 k & (1 << j)) == 1,与运算后的1可能不在末位sb.append(s.charAt(j));}}// 获得子序列ssString ss = sb.toString();boolean flag = true;for(int p = 0; p < n; p ++){if(p != i && isSubsequence(ss, strs[p])){flag = false;break;}}if(flag)res = Math.max(res, ss.length());}}return res;}
}

优化

注意到,如果一个str的子序列满足条件“不是其他字符串的子序列”,那个这个子序列无论如何扩充,扩充后的子序列也必定不是其他字符串的子序列
如子序列“abc”不是“qwerty”、“asdfgh”、“zxcvbn”的子序列,那么将“abc”任意扩充为“axbycz”,也必定不是其他字符串的子序列
由此推出,若str的一个子序列满足条件,那么str本身也必定满足条件

由此问题转化为,判断str[ i ]是否是其他strs的子序列,找出最长的一个str[ i ]返回长度

class Solution {public boolean isSubsequence(String s, String t) {int m = s.length();int n = t.length();int ls = 0;int lt = 0;while(ls < m && lt < n){if(s.charAt(ls) == t.charAt(lt)){ls ++;}lt ++;}return ls == m;}public int findLUSlength(String[] strs) {int n = strs.length;int ans = -1;for(int i = 0; i < n ; i++){String s = strs[i];// 避免计算更小的答案int len = s.length();if(len <= ans)continue;boolean flag = true;for(int j = 0; j < n; j ++){if(i != j && isSubsequence(s, strs[j])){flag = false;break;}}if(flag)ans = Math.max(ans, s.length());}return ans;}
}

这篇关于Leetcode 522. 最长特殊序列 II (判断子序列 优化)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1072071

相关文章

Spring Boot基于 JWT 优化 Spring Security 无状态登录实战指南

《SpringBoot基于JWT优化SpringSecurity无状态登录实战指南》本文介绍如何使用JWT优化SpringSecurity实现无状态登录,提高接口安全性,并通过实际操作步骤... 目录Spring Boot 实战:基于 JWT 优化 Spring Security 无状态登录一、先搞懂:为什

Java JAR 启动内存参数配置指南(从基础设置到性能优化)

《JavaJAR启动内存参数配置指南(从基础设置到性能优化)》在启动Java可执行JAR文件时,合理配置JVM内存参数是保障应用稳定性和性能的关键,本文将系统讲解如何通过命令行参数、环境变量等方式... 目录一、核心内存参数详解1.1 堆内存配置1.2 元空间配置(MetASPace)1.3 线程栈配置1.

java中判断json key是否存在的几种方法

《java中判断jsonkey是否存在的几种方法》在使用Java处理JSON数据时,如何判断某一个key是否存在?本文就来介绍三种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目http://www.chinasem.cn录第一种方法是使用 jsONObject 的 has 方法

Docker多阶段镜像构建与缓存利用性能优化实践指南

《Docker多阶段镜像构建与缓存利用性能优化实践指南》这篇文章将从原理层面深入解析Docker多阶段构建与缓存机制,结合实际项目示例,说明如何有效利用构建缓存,组织镜像层次,最大化提升构建速度并减少... 目录一、技术背景与应用场景二、核心原理深入分析三、关键 dockerfile 解读3.1 Docke

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

从原理到实战解析Java Stream 的并行流性能优化

《从原理到实战解析JavaStream的并行流性能优化》本文给大家介绍JavaStream的并行流性能优化:从原理到实战的全攻略,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的... 目录一、并行流的核心原理与适用场景二、性能优化的核心策略1. 合理设置并行度:打破默认阈值2. 避免装箱

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

Java实现复杂查询优化的7个技巧小结

《Java实现复杂查询优化的7个技巧小结》在Java项目中,复杂查询是开发者面临的“硬骨头”,本文将通过7个实战技巧,结合代码示例和性能对比,手把手教你如何让复杂查询变得优雅,大家可以根据需求进行选择... 目录一、复杂查询的痛点:为何你的代码“又臭又长”1.1冗余变量与中间状态1.2重复查询与性能陷阱1.