Day16(贪心算法)——LeetCode45.跳跃游戏II763.划分字母区间

1 LeetCode45.跳跃游戏II

1.1 题目描述

  与跳跃游戏类似,跳跃游戏II给定长为n的从0开始索引的整数数组numsnums[i]是你在i处能向右跳跃的最大步数,求到达数组最后一个索引处需要跳跃的最少次数。
  一个示例:nums[2,3,1,1,4],则到达下标4的位置需要跳至少两次,即从下标0跳到下标1,再从下标1跳到下标4

1.2 问题分析及解决

  贪心的思想,即在当前位置所能跳跃的范围内,选择跳跃到有最大跳跃长度的位置。例如nums=[2,3,1,1,4],从下标0可以跳跃到下标1、下标2,但下标1最大跳跃长度为3,比下标2的最大跳跃长度大,因此我们选择跳跃到下标1。
  像上面的思路我们貌似需要每一次遍历数组的一小部分决定下一步要走到哪,这样的话时间复杂度为 O ( n 2 ) O(n^2) O(n2)。可以换个角度,但本质上与上述思路相同。
  我们从一个位置跳跃到其能跳远的最远长度所在的下标now_right的过程中,记录下这之间的所有位置能达到的最远位置的下标max_right,若我们到达了now_right,但仍没到最后一个下标,此时步数就得+1。因为相当于我们回头从具有最大跳跃长度的位置开始跳(步数+1),而回头不需要步数。
  仍以上述为例,nums=[2,3,1,1,4],我们从nums[0]开始跳,其最远可以到达nums[0]+0=2(now_right=2),并记录下在其跳跃范围内的位置能到达的最远下标nums[1]+1=4(max_right=4)。当我们跳到下标2时,我们无法从nums[0]开始再往右跳,因此需要步数+1,从nums[1]起跳,由于我们记录了从nums[1]起跳最远能到达下标4,因此我们只需更新now_right=max_right即可,然后继续上述操作。注意我们只需要判断最远距离能否到达倒数第2个下标,因为若能从某个位置直接到最后一个下标,这不算步数,因此只需判断能否到达倒数第二个下标,若能则肯定也能到最后一个下标;若不能则步数+1就能到达最后一个下标了。
  具体实现如下:

class Solution {
public:int jump(vector<int>& nums) {int ans=0;//记录跳跃过程中能到达的最大下标int maxright=0;//记录从当前位置跳跃能到达的最大下标int nowright=0;for(int i=0;i<nums.size()-1;i++){maxright=max(maxright,nums[i]+i);//如果此时还没到最后一个下标if(i==nowright){//步数+1,从而才能继续向前nowright=maxright;ans++;}}return ans;}
};

2 LeetCode763.划分字母区间

2.1 题目描述

  给定一个字符串s,将字符串划分为尽可能多的片段,同一字母最多出现在一个片段中。如s="ababcc",则最终的划分结果为["abab","cc"]。返回表示每个字符串片段的长度的列表。
  一个示例如下:
1

2.2 问题分析及解决

  贪心的思想,从第一个字母开始遍历,定义指针left指向划分的最左边,right指向划分的最右边,因此right要更新为遍历字母中最后出现的位置的最大值,直到遍历位置与right相等,说明leftright之间就是一个划分。更新left=right+1,继续上述操作即可。
  具体实现如下:


class Solution {
public:vector<int> partitionLabels(string s) {vector<int> ans;int end_char[26];//记录每个字母最后出现的位置for(int i=0;i<s.length();i++){end_char[s[i]-'a']=i;}//记录遍历过程中每个字母最后一次出现的位置int right=0;//划分的左边int left=0;//划分的右边int partition=-1;for(int i=0;i<s.length();i++){right=end_char[s[i]-'a'];//划分右边为遍历字母最后一次出现位置的最大值partition=max(partition,right);//如果遍历到划分位置,则说明是一个划分if(i==partition){ans.push_back(partition-left+1);left=right+1;}}return ans;}
};

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

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

相关文章

告别碎片化!两大先进分块技术如何提升RAG的语义连贯性?

研究动机 论文核心问题及研究背景分析 1. 研究领域及其重要性 研究领域&#xff1a;检索增强生成&#xff08;Retrieval-Augmented Generation, RAG&#xff09;系统&#xff0c;结合自然语言处理&#xff08;NLP&#xff09;与信息检索技术。重要性&#xff1a; RAG通过动态…

leetcode day37 474

474 一和零 给你一个二进制字符串数组 strs 和两个整数 m 和 n 。 请你找出并返回 strs 的最大子集的长度&#xff0c;该子集中 最多 有 m 个 0 和 n 个 1 。 如果 x 的所有元素也是 y 的元素&#xff0c;集合 x 是集合 y 的 子集 。 示例 1&#xff1a; 输入&#xff1a;s…

二、信息时代社会结构的转变

到了信息时代,以及在核武器的前提下,上述的社会结构的逻辑,就有了一个根 本性的转变,就是暴力的成本和收益,都在下降。 暴力的成本在降低。比如说枪支,它的制造和分发都变得非常容易。现在我们都 知道有 3D 打印,它就好像工业时代的印刷机,印刷圣经或者书籍,使知识更加 普及和容…

Elasticsearch 堆内存使用情况和 JVM 垃圾回收

作者&#xff1a;来自 Elastic Kofi Bartlett 探索 Elasticsearch 堆内存使用情况和 JVM 垃圾回收&#xff0c;包括最佳实践以及在堆内存使用过高或 JVM 性能不佳时的解决方法。 堆内存大小是分配给 Elasticsearch 节点中 Java 虚拟机的 RAM 数量。 从 7.11 版本开始&#xff…

C++之类和对象:构造函数,析构函数,拷贝构造,赋值运算符重载

前提&#xff1a;如果一个类是空类&#xff0c;C中空类中真的什么都没有吗&#xff0c;不是的&#xff0c;编译器会自动生成6个默认成员函数。默认成员函数&#xff1a;用户没有显式实现&#xff0c;编译器会生成的成员函数称为默认成员函数。 默认成员函数&#xff1a;构造函…

【专题五】位运算(1):常见位运算操作总结

&#x1f4dd;前言说明&#xff1a; 本专栏主要记录本人的基础算法学习以及LeetCode刷题记录&#xff0c;按专题划分每题主要记录&#xff1a;&#xff08;1&#xff09;本人解法 本人屎山代码&#xff1b;&#xff08;2&#xff09;优质解法 优质代码&#xff1b;&#xff…

小草GrassRouter多卡聚合路由器聚合卫星、MESH网络应用解决方案

一、多网融合解决方案 卫星网络融合‌ 支持接入卫星通信模块&#xff0c;在无地面网络覆盖的极端场景&#xff08;如偏远山区、海洋救援&#xff09;下&#xff0c;形成“5G卫星”双链路冗余传输&#xff0c;卫星链路可作为核心通信备份&#xff0c;确保关键指令和视频数据实…

【Mybatis】Mybatis基础

文章目录 前言一、搭建MyBatis1.1 创建maven工程1.2 加入log4j日志功能1.3 MyBatis的增删改查1.4 核心配置文件详解 二、MyBatis获取参数值的两种方式2.1 单个字面量类型的参数2.2 多个字面量类型的参数2.3 map集合类型的参数2.4 实体类类型的参数2.5 使用Param标识参数 三、 M…

AI四大边界

大模型训练的边界并非由单一因素决定&#xff0c;而是技术、伦理、法律及实际应用需求共同作用的结果。以下从四个维度解析其边界来源&#xff1a; 一、技术边界&#xff1a;资源与能力的双重限制 计算资源瓶颈 成本与算力&#xff1a;大模型训练依赖海量GPU/TPU资源&#xff…

Twitter 工作原理|架构解析|社交APP逻辑

这是对Twitter 工作原理&#xff5c;架构解析&#xff5c;社交APP逻辑_哔哩哔哩_bilibili的学习&#xff0c;感谢up小凡生一 在两年半前&#xff0c;埃隆马斯克收购了Twitter&#xff0c;并且进行了一系列重大改革。今天我们来解析一下这个全球知名社交平台的架构。首先&#x…

Java基础学习内容大纲

Java基础学习内容大纲 第一阶段:建立编程思想 ​ Java概述:如何快速学习Java技术、Java历史、Java特点、Sublime、Java运行机制、JDK、转义字符、Java开发规范、Java API ​ 变量:数据类型、变量基本使用、数据类型转换 ​ 运算符:运算符介绍、算数运算符、关系运算符、…

如何对多维样本进行KS检验

对于形状为 ( 10000 , 1 , 304 ) (10000, 1, 304) (10000,1,304)的三维数据&#xff0c;若需使用scipy.stats.ks_2samp进行KS检验&#xff0c;可按以下步骤处理&#xff1a; 数据降维 KS检验要求输入为一维数组&#xff0c;需将三维数据展平或按特定维度聚合&#xff1a; • 方…

在 VMware 虚拟机中安装 Windows7

文章目录 前言1.安装VMware 虚拟机1. VMware虚拟机软件安装2. 虚拟机创建配置&#xff08;超详细步骤&#xff09;3. Windows7系统安装 3、安装 VMware tools4. VMware Tools安装与优化5. 总结与常见问题 前言 最近有不少朋友在问如何在电脑上同时使用多个操作系统&#xff0c…

直播预告|TinyVue 组件库高级用法:定制你的企业级UI体系

TinyVue 是一个跨端跨框架的企业级 UI 组件库&#xff0c;基于 renderless 无渲染组件设计架构&#xff0c;实现了一套代码同时支持 Vue2 和 Vue3&#xff0c;支持 PC 和移动端&#xff0c;包含 100 多个功能丰富的精美组件&#xff0c;可帮助开发者高效开发 Web 应用。 4 月 …

分治而不割裂—分治协同式敏捷工作模式

分治而不割裂&#xff1a;解密敏捷协同工作模式如何驱动大企业持续领跑 在数字化浪潮中&#xff0c;亚马逊仅用11天完成Prime Day全球技术架构升级&#xff0c;华为5G基站项目组创造过单周迭代47个功能模块的纪录&#xff0c;这些商业奇迹的背后&#xff0c;都隐藏着一个共性秘…

Python列表全面解析:从基础到高阶操作

一、为什么需要列表&#xff1f; 在Python中&#xff0c;列表是可变有序序列&#xff0c;用于存储多个元素的容器。相较于单一变量存储独立值&#xff0c;列表能更高效地管理批量数据&#xff0c;其特点包括&#xff1a; ​引用存储&#xff1a;列表元素存储的是对象的引用​…

Spring知识点梳理

一、Spring&#xff08;Spring Framework&#xff09; 1、IOC&#xff08;控制反转&#xff09; 1&#xff09;什么是IOC控制反转&#xff1f; 为了解藕&#xff0c;有反转就有“正转”&#xff0c;“正转”就是程序员手动 new对象&#xff1b;“反转”就是将对象的创建、对…

SpringBoot启动后自动执行方法的各种方式-笔记

1. SpringBoot启动后自动执行方法的各种方式 1.1 PostConstruct 注解 作用&#xff1a;在依赖注入完成后执行初始化方法。 适用场景&#xff1a;需要在Bean初始化时执行某些操作&#xff08;如配置、预加载数据&#xff09;。 注意&#xff1a;该方法在Bean初始化阶段执行&…

基础知识-java流steam

Java Stream 流详解 一、Stream 概述 #mermaid-svg-ZXmu5UZgAcGGq8EN {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-ZXmu5UZgAcGGq8EN .error-icon{fill:#552222;}#mermaid-svg-ZXmu5UZgAcGGq8EN .error-text{fil…

8.Android(通过Manifest配置文件传递数据(meta-data))

配置文件 <?xml version"1.0" encoding"utf-8"?> <manifest xmlns:android"http://schemas.android.com/apk/res/android"xmlns:tools"http://schemas.android.com/tools"><applicationandroid:allowBackup"tr…