【Leetcode 每日一题】2900. 最长相邻不相等子序列 I

问题背景

给你一个下标从 0 0 0 开始的字符串数组 w o r d s words words,和一个下标从 0 0 0 开始的 二进制 数组 g r o u p s groups groups,两个数组长度都是 n n n
你需要从 w o r d s words words 中选出 最长子序列。如果对于序列中的任何两个连续串,二进制数组 g r o u p s groups groups 中它们的对应元素不同,则 w o r d s words words 的子序列是不同的。
正式来说,你需要从下标 [ 0 , 1 , . . . , n − 1 ] [0, 1, ..., n - 1] [0,1,...,n1] 中选出一个 最长子序列 ,将这个子序列记作长度为 k k k [ i 0 , i 1 , . . . , i k − 1 ] [i_0, i_1, ..., i_{k - 1}] [i0,i1,...,ik1],对于所有满足 0 ≤ j < k − 1 0 \le j < k - 1 0j<k1 j j j 都有 g r o u p s [ i j ] ≠ g r o u p s [ i j + 1 ] groups[i_j] \ne groups[i_j + 1] groups[ij]=groups[ij+1]
请你返回一个字符串数组,它是下标子序列 依次 对应 w o r d s words words 数组中的字符串连接形成的字符串数组。如果有多个答案,返回 任意 一个。
注意: w o r d s words words 中的元素是不同的 。

数据约束

  • 1 ≤ n = w o r d s . l e n g t h = g r o u p s . l e n g t h ≤ 100 1 \le n = words.length = groups.length \le 100 1n=words.length=groups.length100
  • 1 ≤ w o r d s [ i ] . l e n g t h ≤ 10 1 \le words[i].length \le 10 1words[i].length10
  • g r o u p s [ i ] groups[i] groups[i] 0 0 0 1 1 1
  • w o r d s words words 中的字符串 互不相同
  • w o r d s [ i ] words[i] words[i] 只包含小写英文字母。

解题过程

这题实际上是一个分组问题,将所有连续相同的字符看作是一组,每一组中只选择一个就可以保证相同组的元素不连续出现。

具体实现

class Solution {public List<String> getLongestSubsequence(String[] words, int[] groups) {List<String> res = new ArrayList<>();int n = groups.length;for (int i = 0; i < n; i++) {if (i == n - 1 || groups[i] != groups[i + 1]) {res.add(words[i]);}}return res;}
}

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

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

相关文章

ProfibusDP主站转ModbusRTU/TCP与横河AXG电磁流量计通讯案例

ProfibusDP主站转ModbusRTU/TCP与横河AXG电磁流量计通讯案例 在当今数字化工业时代&#xff0c;智能仪表与控制系统的互联互通成为提高生产效率和管理水平的关键。横河AXG电磁流量计作为一款高性能的流量测量设备&#xff0c;在多个行业得到了广泛应用。而Profibus DP作为一种…

微软向现实低头:悄悄延长Windows 10的Microsoft 365支持

快科技5月11日消息&#xff0c;Windows 10将在今年10月14日正式结束支持&#xff0c;此前微软曾明确表示&#xff0c;Microsoft 365&#xff08;M365&#xff09;应用&#xff0c;如Outlook、Teams、OneDrive、Word、Excel等&#xff0c;也将随之停止支持。 不过无法升级至Win…

【Spring AI】模型记忆持久化 + 自动加载记忆上下文

当我们利用大模型进行开发时&#xff0c;有时会因为项目重启而丢失模型的记忆&#xff0c;会给开发的过程带来不方便 接下来我将介绍如何将模型的记忆持久化&#xff0c;并保证在项目重启后依然能能够正常加载记忆上下文。 我们在配置ChatClient时&#xff0c;由于想要实现模…

(C语言)超市管理系统 (正式版)(指针)(数据结构)(清屏操作)(文件读写)

目录 前言&#xff1a; 源代码&#xff1a; product.h product.c fileio.h fileio.c main.c 代码解析&#xff1a; 一、程序结构概述 二、product.c 函数详解 1. 初始化商品列表 Init_products 2. 添加商品 add_product 3. 显示商品 display_products 4. 修改商品 mo…

[服务器面板对比] 宝塔、aaPanel、Plesk、cPanel 哪家强?功能、性能与价格横评 (2025)

对于很多 Linux 服务器用户来说&#xff0c;直接面对黑乎乎的命令行界面 (CLI) 进行各种操作&#xff0c;虽然强大灵活&#xff0c;但也确实有一定的学习门槛和操作复杂度。特别是当你需要管理多个网站、数据库、FTP账户&#xff0c;或者进行日常的软件安装、安全配置、日志查看…

WebGL图形编程实战【7】:变换流水线 × 坐标系与矩阵精讲

变换流水线 #mermaid-svg-Omabd9LSNCdIvWqB {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-Omabd9LSNCdIvWqB .error-icon{fill:#552222;}#mermaid-svg-Omabd9LSNCdIvWqB .error-text{fill:#552222;stroke:#552222;…

电力电容器故障利用沃伦森(WARENSEN)工业设备智能运维系统解决方案

行业工况背景 当配电室报警显示“电容器故障”时&#xff0c;管理者可能会感到焦虑。沃伦森&#xff08;WARENSEN&#xff09;凭借十多年的电力补偿设备服务经验&#xff0c;提供了科学的故障应对流程&#xff0c;帮助避免大部分二次损失。 一、五大常见故障现象快速识别 温度…

星海智算云平台部署GPT-SoVITS模型教程

背景 随着 GPT-SoVITS 在 AI 语音合成领域的广泛应用&#xff0c;越来越多的个人和团队开始关注这项前沿技术。你是否也在思考&#xff0c;如何快速、高效地部署并体验这款强大的声音克隆模型&#xff1f;遗憾的是&#xff0c;许多本地部署方案不仅配置复杂&#xff0c;而且对…

高吞吐与低延迟的博弈:Kafka与RabbitMQ数据管道实战指南

摘要 本文全面对比Apache Kafka与RabbitMQ在数据管道中的设计哲学、核心差异及协同方案。结合性能指标、应用场景和企业级实战案例,揭示Kafka在高吞吐流式处理中的优势与RabbitMQ在复杂路由和低延迟传输方面的独特特点;介绍了使用Java生态成熟第三方库(如Apache Kafka Clie…

Python零基础入门到高手8.4节: 元组与列表的区别

目录 8.4.1 不可变数据类型 8.4.2 可变数据类型 8.4.3 元组与列表的区别 8.4.4 今天彩票没中奖 8.4.1 不可变数据类型 不可变数据类型是指不可以对该数据类型进行原地修改&#xff0c;即只读的数据类型。迄今为止学过的不可变数据类型有字符串&#xff0c;元组。 在使用[]…

无人机数据处理与特征提取技术分析!

一、运行逻辑 1. 数据采集与预处理 多传感器融合&#xff1a;集成摄像头、LiDAR、IMU、GPS等传感器&#xff0c;通过硬件时间戳或PPS信号实现数据同步&#xff0c;确保时空一致性。 边缘预处理&#xff1a;在无人机端进行数据压缩&#xff08;如JPEG、H.265&#xff09;…

LeetCode 热题 100 105. 从前序与中序遍历序列构造二叉树

LeetCode 热题 100 | 105. 从前序与中序遍历序列构造二叉树 大家好&#xff0c;今天我们来解决一道经典的二叉树问题——从前序与中序遍历序列构造二叉树。这道题在 LeetCode 上被标记为中等难度&#xff0c;要求根据给定的前序遍历和中序遍历序列&#xff0c;构造并返回二叉树…

CSS- 1.1 css选择器

本系列可作为前端学习系列的笔记&#xff0c;代码的运行环境是在HBuilder中&#xff0c;小编会将代码复制下来&#xff0c;大家复制下来就可以练习了&#xff0c;方便大家学习。 HTML系列文章 已经收录在前端专栏&#xff0c;有需要的宝宝们可以点击前端专栏查看&#xff01; 系…

MongoClient和AsyncIOMotorClient的区别和用法

示例代码&#xff1a; from motor.motor_asyncio import AsyncIOMotorClient from pymongo import MongoClient&#x1f50d; 这两个库分别是&#xff1a; 名字说明举个例子pymongo.MongoClient同步版 的 MongoDB 客户端&#xff08;常规阻塞式操作&#xff09;你在主线程里一…

5.15打卡

浙大疏锦行 DAY 26 函数专题1 知识点回顾&#xff1a; 1. 函数的定义 2. 变量作用域&#xff1a;局部变量和全局变量 3. 函数的参数类型&#xff1a;位置参数、默认参数、不定参数 4. 传递参数的手段&#xff1a;关键词参数 5. 传递参数的顺序&#xff1a;同时出现三种参数…

针对面试-mysql篇

1.如何定位慢查询? 1.1.介绍一下当时产生问题的场景(我们当时的接口测试的时候非常的慢&#xff0c;压测的结果大概5秒钟))&#xff0c;可以监测出哪个接口&#xff0c;最终因为是sql的问题 1.2.我们系统中当时采用了运维工具(Skywalking就是2秒&#xff0c;一旦sql执行超过2秒…

window 显示驱动开发-报告图形内存(三)

图形内存报告示例 示例 1&#xff1a;笔记本电脑上的 128 MB 专用板载图形内存 以下屏幕截图显示了使用 Intel Iris 离散图形适配器运行 Windows 11 的 Surface 笔记本电脑的计算图形内存数。 适配器的可用内存总数为 16424 MB&#xff0c;用于图形用途&#xff0c;细分如下&…

极简主义现代商务风格PPT模版6套一组分享下载

现代商务风格PPT模版下载https://pan.quark.cn/s/12fbc52124d9 第一张PPT模版&#xff0c;简约风&#xff0c;橄榄绿背景&#xff0c;黑色竖条装饰&#xff0c;文字有中英文标题和占位符。需要提取关键元素&#xff1a;简约、橄榄绿、对称布局、占位文本的位置。 风格​&#…

SpringBoot中10种动态修改配置的方法

在SpringBoot应用中&#xff0c;配置信息通常通过application.properties或application.yml文件静态定义&#xff0c;应用启动后这些配置就固定下来了。 但我们常常需要在不重启应用的情况下动态修改配置&#xff0c;以实现灰度发布、A/B测试、动态调整线程池参数、切换功能开…

嵌入式自学第二十二天(5.15)

顺序表和链表 优缺点 存储方式&#xff1a; 顺序表是一段连续的存储单元 链表是逻辑结构连续物理结构&#xff08;在内存中的表现形式&#xff09;不连续 时间性能&#xff0c; 查找顺序表O(1)&#xff1a;下标直接查找 链表 O(n)&#xff1a;从头指针往后遍历才能找到 插入和…