Leetcode每日一题2055. 蜡烛之间的盘子 前缀和+预处理 dp多次超时之后的反思

本文主要是介绍Leetcode每日一题2055. 蜡烛之间的盘子 前缀和+预处理 dp多次超时之后的反思,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

📖本篇内容:Leetcode每日一题2055. 蜡烛之间的盘子 前缀和+预处理 / 二分

📑 文章专栏:leetcode每日一题《打卡日常》

📆 最近更新:2022年3月7日 Leetcode每日一题 504. 七进制数 简单的模拟进制计算 / 栈的合理运用 /JDK源码API的理解与使用

⭐算法仓库:小付的算法之路——Alascanfu-algorithm.git.io

🙊个人简介:一只二本院校在读的大三程序猿,本着注重基础,打卡算法,分享技术作为个人的经验总结性的博文博主,虽然可能有时会犯懒,但是还是会坚持下去的,如果你很喜欢博文的话,建议看下面一行~(疯狂暗示QwQ)

🌇 点赞 👍 收藏 ⭐留言 📝 一键三连 关爱程序猿,从你我做起

🙊本文目录👍

  • 🙊写在前面🙊
  • 题目
    • 提示
    • 📝思路📝
    • ⭐代码实现⭐
    • 运行结果
  • 🙊写在最后🙊

🙊写在前面🙊

来了来了,吃过午饭就来写题解啦~

题目

给你一个长桌子,桌子上盘子和蜡烛排成一列。给你一个下标从 0 开始的字符串 s ,它只包含字符 ‘’ 和 ‘|’ ,其中 '’ 表示一个 盘子 ,’|’ 表示一支 蜡烛 。

同时给你一个下标从 0 开始的二维整数数组 queries ,其中 queries[i] = [lefti, righti] 表示 子字符串 s[lefti…righti] (包含左右端点的字符)。对于每个查询,你需要找到 子字符串中 在 两支蜡烛之间 的盘子的 数目 。如果一个盘子在 子字符串中 左边和右边 都 至少有一支蜡烛,那么这个盘子满足在 两支蜡烛之间 。

比方说,s = “||**||**|*” ,查询 [3, 8] ,表示的是子字符串 “*||**|” 。子字符串中在两支蜡烛之间的盘子数目为 2 ,子字符串中右边两个盘子在它们左边和右边 都 至少有一支蜡烛。
请你返回一个整数数组 answer ,其中 answer[i] 是第 i 个查询的答案。

示例1:
在这里插入图片描述

输入:s = "**|**|***|", queries = [[2,5],[5,9]]
输出:[2,3]
解释:
- queries[0] 有两个盘子在蜡烛之间。
- queries[1] 有三个盘子在蜡烛之间。

示例2:
在这里插入图片描述

输入:s = "***|**|*****|**||**|*", queries = [[1,17],[4,5],[14,17],[5,11],[15,16]]
输出:[9,0,0,0,0]
解释:
- queries[0] 有 9 个盘子在蜡烛之间。
- 另一个查询没有盘子在蜡烛之间。

提示

  • 3 <= s.length <= 10^5
  • s 只包含字符 '*' 和 '|' 。
  • 1 <= queries.length <= 10^5
  • queries[i].length == 2
  • 0 <= lefti <= righti < s.length

📝思路📝

本题考查知识点

  • 思路:这道题小付在凌晨的时候就尝试的做了一下,用的是 dp 也是统计当前盘子下标位置时的左侧的蜡烛个数与当前盘子位置下标位置时的右侧的蜡烛个数,毫无疑问超时了O( n*m )的时间复杂度 同时也开辟了3个数组空间用于存储数据所以就只好睡觉一早起来想了。
  • 第二天一早想着前天的前缀和与预处理的方法以及uu们的提示我就知道了这道题是可以采用前缀和+预处理来解决的,不过这里我们的预处理的左右侧蜡烛就不再是个数 ,反而是左右侧最近的蜡烛下标是否在我们的子字符串范围内,这样一来就只需要一次遍历就可以进行预处理,判断当前位置下的左侧最近右侧最近蜡烛位置下标是否没有重合且在子字符串的范围之内,则可以记录当前位置下的满足条件的盘子个数

⭐代码实现⭐

模拟进制计算

class Solution {public int[] platesBetweenCandles(String s, int[][] queries) {int m = s.length();int n = queries.length;// 分别用于记录当前位置下其左侧最近的蜡烛下标位置,以及当前位置下右侧最近的蜡烛下标位置int[] leftNearestCan = new int [m+1],rightNearestCan = new int [m+1],prefix = new int[m+1];// 初始化边界 如果找不到最近的蜡烛 则直接返回边界位置leftNearestCan[0] = -1;rightNearestCan[m] = m;// 预处理for (int i = 1;i<=m;i++){// 用来求取当前位置的盘子个数prefix[i] = prefix[i-1] + (s.charAt(i-1) == '*' ? 1 : 0);// 这里是获取当前位置下 左侧最近的蜡烛下标leftNearestCan[i] = (s.charAt(i-1) == '|' ? i-1 : leftNearestCan[i-1]);// 这里是获取当前位置下 右侧最近的蜡烛下标rightNearestCan[m-i] = (s.charAt(m-i) == '|'? m-i : rightNearestCan[m-i+1]);}int[] res = new int [n];for (int i = 0 ; i< n;i++){// 记录当前查询位置的右侧最近的Idx,以及当前查询位置的左侧最近|的 Idxint lIdx = rightNearestCan[queries[i][0]],  rIdx = leftNearestCan[queries[i][1] + 1];// 为了防止当前查询左右位置相同 也就是子字符串为1的情况下 跳过当前查询if(lIdx+1 >= rIdx)continue;// 前缀和计算当前位置的满足条件的盘子个数res[i] = prefix[rIdx+1] - prefix[lIdx]; }return res;}
}
  • 时间复杂度:O(n+m)
  • 空间复杂度:O(m) 这里开了两个大小为m+1的记录左侧下标位置和右侧下标位置的数组 结果数组不计入

运行结果

前缀和 + 预处理
在这里插入图片描述

🙊写在最后🙊

2022-3-8今天小付打卡了哦~

美好的日出 美好的山河

都因有你存在 而璀璨 耀眼

在这里插入图片描述

这篇关于Leetcode每日一题2055. 蜡烛之间的盘子 前缀和+预处理 dp多次超时之后的反思的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏

504 Gateway Timeout网关超时的根源及完美解决方法

《504GatewayTimeout网关超时的根源及完美解决方法》在日常开发和运维过程中,504GatewayTimeout错误是常见的网络问题之一,尤其是在使用反向代理(如Nginx)或... 目录引言为什么会出现 504 错误?1. 探索 504 Gateway Timeout 错误的根源 1.1 后端

Java中数组与栈和堆之间的关系说明

《Java中数组与栈和堆之间的关系说明》文章讲解了Java数组的初始化方式、内存存储机制、引用传递特性及遍历、排序、拷贝技巧,强调引用数据类型方法调用时形参可能修改实参,但需注意引用指向单一对象的特性... 目录Java中数组与栈和堆的关系遍历数组接下来是一些编程小技巧总结Java中数组与栈和堆的关系关于

在Java中实现线程之间的数据共享的几种方式总结

《在Java中实现线程之间的数据共享的几种方式总结》在Java中实现线程间数据共享是并发编程的核心需求,但需要谨慎处理同步问题以避免竞态条件,本文通过代码示例给大家介绍了几种主要实现方式及其最佳实践,... 目录1. 共享变量与同步机制2. 轻量级通信机制3. 线程安全容器4. 线程局部变量(ThreadL

C语言进阶(预处理命令详解)

《C语言进阶(预处理命令详解)》文章讲解了宏定义规范、头文件包含方式及条件编译应用,强调带参宏需加括号避免计算错误,头文件应声明函数原型以便主函数调用,条件编译通过宏定义控制代码编译,适用于测试与模块... 目录1.宏定义1.1不带参宏1.2带参宏2.头文件的包含2.1头文件中的内容2.2工程结构3.条件编

Javaee多线程之进程和线程之间的区别和联系(最新整理)

《Javaee多线程之进程和线程之间的区别和联系(最新整理)》进程是资源分配单位,线程是调度执行单位,共享资源更高效,创建线程五种方式:继承Thread、Runnable接口、匿名类、lambda,r... 目录进程和线程进程线程进程和线程的区别创建线程的五种写法继承Thread,重写run实现Runnab

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

Python设置Cookie永不超时的详细指南

《Python设置Cookie永不超时的详细指南》Cookie是一种存储在用户浏览器中的小型数据片段,用于记录用户的登录状态、偏好设置等信息,下面小编就来和大家详细讲讲Python如何设置Cookie... 目录一、Cookie的作用与重要性二、Cookie过期的原因三、实现Cookie永不超时的方法(一)

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1