LeetCode 1871. 跳跃游戏 VII(贪心)

文章目录

    • 1. 题目
    • 2. 解题

1. 题目

给你一个下标从 0 开始的二进制字符串 s 和两个整数 minJumpmaxJump
一开始,你在下标 0 处,且该位置的值一定为 '0'
当同时满足如下条件时,你可以从下标 i 移动到下标 j 处:

  • i + minJump <= j <= min(i + maxJump, s.length - 1)
  • s[j] == '0'.

如果你可以到达 s 的下标 s.length - 1 处,请你返回 true ,否则返回 false 。

示例 1:
输入:s = "011010", minJump = 2, maxJump = 3
输出:true
解释:
第一步,从下标 0 移动到下标 3 。
第二步,从下标 3 移动到下标 5 。示例 2:
输入:s = "01101110", minJump = 2, maxJump = 3
输出:false提示:
2 <= s.length <= 10^5
s[i] 要么是 '0' ,要么是 '1'
s[0] == '0'
1 <= minJump <= maxJump < s.length

来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/jump-game-vii
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

类似题目:
LeetCode 55. 跳跃游戏(贪心)

  • 创建访问标记 vis,并且记录最远可达的位置,保证每个位置不重复访问,O(n)O(n)O(n) 时间复杂度
class Solution {
public:bool canReach(string s, int minJump, int maxJump) {if(s.back() == '1')return false;int n = s.size(), end = 0;//最远可到达的位置 endvector<bool> vis(n, false);vis[0] = true;for(int i = 0; i < n && i <= end; i++){if(!vis[i]) continue;int p1 = i+minJump;int p2 = min(n-1, i+maxJump);for(int j = max(p1, end+1); j <= p2; ++j)//max保证每个位置只检查1次{if(s[j] == '0'){vis[j] = true;if(j == n-1)//走到最后了return true;}}end = p2;//更新end位置}return false;}
};

44 ms 15.7 MB C++


我的CSDN博客地址 https://michael.blog.csdn.net/

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!
Michael阿明

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

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

相关文章

pcb外观维修_「维修案例」泰克AFG3021函数任意波形发生器故障维修

在产品调试的过程中&#xff0c;大多数的电路需要输入某种幅度随时间变化的信号&#xff0c;在这样的应用场景中&#xff0c;一个完整的测试测量系统一般会包含激励源&#xff0c;被测件和采集仪器三个部分。采集仪器通常使用的是示波器和逻辑分析仪&#xff0c;而信号源在系统…

sass 安装和使用

1&#xff0c;安装ruby :检查本地是否安装ruby&#xff1a; #ruby -v 2&#xff0c;安装sass&#xff1a; #gem install sass 3&#xff0c;检查是否安装成功&#xff1a;#sass -v 4&#xff0c;.scss文件不能直接被浏览器解析&#xff0c;需要转化成css文件&#xff0c;您不必…

设计模式--迭代器模式

实验18&#xff1a;迭代器模式 本次实验属于模仿型实验&#xff0c;通过本次实验学生将掌握以下内容&#xff1a; 1、理解迭代器模式的动机&#xff0c;掌握该模式的结构&#xff1b; 2、能够利用迭代器模式解决实际问题。 [实验任务]&#xff1a;JAVA和C常见数据结构迭代…

4k视频分辨率的码流_8K电视来了!但是8K视频仍很遥远

本届CES上&#xff0c;8K电视的集体发布可谓一大亮点&#xff0c;索尼、LG、TCL、三星等厂商纷纷推出8K电视。不光如此&#xff0c;本届CES上夏普突如其来的展示了一款具备8K视频拍摄功能的M43相机&#xff0c;这一点着实是出乎意料。今天我们就来讨论一下&#xff0c;在8K电视…

LeetCode 1707. 与数组中元素的最大异或值(Trie树)

文章目录1. 题目2. 解题1. 题目 给你一个由非负整数组成的数组 nums 。另有一个查询数组 queries &#xff0c;其中 queries[i] [xi, mi] 。 第 i 个查询的答案是 xi 和任何 nums 数组中不超过 mi 的元素按位异或&#xff08;XOR&#xff09;得到的最大值。 换句话说&#x…

wu

&#xff40;&#xff40;&#xff40;&#xff40;&#xff40;看我的csdn博客吧http://blog.csdn.net/wwx_from_tju转载于:https://www.cnblogs.com/wwxtju/p/4374918.html

学报格式和论文格式一样吗_学报参考文献标准格式

学报参考文献标准格式毕业论文参考文献规范格式是怎么样的&#xff1f;怎么样才是标准的&#xff0c;看看下面的学报参考文献标准格式吧&#xff01;学报参考文献标准格式一、参考文献的类型参考文献(即引文出处)的.类型以单字母方式标识&#xff0c;具体如下&#xff1a;M——…

我的爬虫第一天

爬虫一个简单的爬虫&#xff1a;1.安装request2.测试是否安装成功3.新建项目4.使用requests请求网页4.如何用python解析网页源码5.简单的保存数据的方法一个简单的爬虫&#xff1a; 1.安装request pip install requests2.测试是否安装成功 输入python import requests不报…

qr分解求线性方程组_计算方法/数值分析第三章 线性方程组的数值解法

主要内容&#xff1a;1、引言2、高斯消去法3、直接分解法4、解线性方程组的迭代法5、向量范数、矩阵范数及迭代法的收敛性第一节 引言用克拉姆求解线性方程组第二节 高斯消去法高斯消去法是一种古老的直接法&#xff0c;其基本思想是通过消元将线性方程组的求解问题转化成三角形…

判断成绩及格优良

依旧是if语句的简单练习 if嵌套&#xff0c;满足前提条件才能执行条件下的语句 namespace ConsoleApplication9 {class Program{static void Main(string[] args){while (true){Console.Write("请输入姓名&#xff1a;");Console.ReadLine();Console.Write("请输…

python 执行完成后,cmd窗口自动关闭

一般脚本运行完需要点击一下 在代码最后添加以下内容即可自动关闭cmd&#xff1a; import os import time time.sleep(1) # 方便展示&#xff0c;可删除 os.system("taskkill /f /im cmd.exe") # 关闭cmd窗口

txt文件可存储最大值_Verilog边码边学:十六进制文件读取$readmemh

系统任务$readmemh读取十六进制文件。$readmemh的作用是将文件中的数据一次性的读入某个数组中&#xff0c;然后可以依次从数组中取出单个的数据进行处理。读取的内容只包括空白位置(空格、换行、制表格)、注释行、十六进制的数字。语法结构中的起始地址与终止地址可省略。【语…

什么叫诚实_他爱不爱你,身体最诚实

文字&#xff1a;嘉一 声音&#xff1a;三三有位听友给我发私信说&#xff1a;“他看我的眼神变了&#xff0c;也不喜欢和我说话了&#xff0c;更懒得为我做任何事了&#xff0c;这段感情真的没意思了。”我回她&#xff1a;“一个人爱不爱你&#xff0c;身体最诚实。嘴巴可以…

【机器学习-数据科学】第一节:numpypandas

numpy&pandas安装numpy&pandasarray创建numpy的基础运算numpy的索引numpy的 array 合并numpy的 array分割numpy的 copy & deep copy安装numpy&pandas import numpy as np arraynp.array([[1,2,3],[2,3,4]])# 将数组转化为矩阵 print(array) #打印矩阵 print(nu…

python 剪切一行内容到另一个文件

自己做机器学习项目&#xff0c;手动打标签&#xff0c;完成后剪切一行数据到文件 参考内容&#xff1a;https://www.cnblogs.com/Dreamer-qiao/p/7390469.html # 剪切一行数据到另外一个文件 # 用途&#xff1a;自己做机器学习数据&#xff0c;打标签&#xff0c;标记source…

[整理]详记被忽略的Get与Post

[事发]使用了近5年的项目&#xff0c;来了一个最最基本的bug画面输入号&#xff0c;跳转至后画面&#xff0c;号变成了空格&#xff01;[原因]画面使用url(get)方法传参数&#xff0c;并且没有进行url转码&#xff01;恐怖的是&#xff0c;几乎所有页面都是如此...[解决办法]1.…

【机器学习-数据科学】第二节:ipython开发环境搭建以及pandas快速入门

ipython开发环境搭建以及pandas快速入门0.开发环境搭建技巧网页版ipython&#xff1a;ipython notebooknumpy1.pandas 快速入门一导入创建对象2. pandas 快速入门二空数据处理apply的用法count和mode函数数据合并3. pandas 快速入门三数据整形数据透视时间序列数据可视化数据载…

pytorch图像和张量的相互转换_Day107:Pytorch张量类型的构建与相互转换

张量的作用Pytorch的数据类型为各式各样的Tensor&#xff0c;Tensor可以理解为高维矩阵(与Numpy中的Array类似)通过使用Type函数可以查看变量类型。一CPU张量类型Pytorch中的tensor包括七种CPU张量类型和八种GPU张量类型&#xff0c;这里我们就只讲解一下CPU中的&#xff0c;GP…

漂亮的html页面源码_爬虫数据分析之html

1、 htmlhtml 不是一种编程语言&#xff0c;而是一种标记语言&#xff0c;是制作网页所必须的&#xff0c;你在浏览器里看到的每一个页面&#xff0c;不论简单还是复杂&#xff0c;都是用html编写的&#xff0c;包括你现在看到的这篇文章。用html写一个简单的页面&#xff0c;是…

【leetcode刷题笔记】Excel Sheet Column Number

Related to question Excel Sheet Column Title Given a column title as appear in an Excel sheet, return its corresponding column number. For example: A -> 1B -> 2C -> 3...Z -> 26AA -> 27AB -> 28 题解&#xff1a;其实就是一个26进制数转换成十…