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
英文地址,請注明出處:http://en.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…