代碼隨想錄算法訓練營第三十八天| 435. 無重疊區間 、763.劃分字母區間、56. 合并區間

435. 無重疊區間

題目鏈接:435. 無重疊區間

文檔講解:代碼隨想錄/無重疊區間

視頻講解:視頻講解-無重疊區間

狀態:已完成(1遍)

解題過程?

看到題目的第一想法

這道題我的想法是首先將集合按照start從小到大排序,如果start一樣,局部最優就是把end更大的移除。但是太單薄了,支撐不起題目的要求,想了半天想不到思路,直接看視頻講解吧。

看完代碼隨想錄之后的想法?

找到所有重疊的區間,把重疊的區間去掉就可以了。那么問題難點就在盡可能找到足夠重疊的區間。反而跟前一天的射氣球是一樣的道理。題目換了一種方式,竟然完全想不起來了。。。

看了講解手搓代碼如下:

/*** @param {number[][]} intervals* @return {number}*/
var eraseOverlapIntervals = function(intervals) {let newArr = intervals.sort((a,b)=>a[0]-b[0]);let ans = 0;for(let i = 1;i<newArr.length;i++){if(newArr[i][0]<newArr[i-1][1]){//后一個區間的左端小于前一個區間的右端,即重疊ans++;newArr[i][1] = Math.min(newArr[i-1][1],newArr[i][1]);//將重疊部分的最小右端記錄下來,下一個區間的左端只要大于最小右端,就不會發生重疊。}}return ans;
};

總結

同樣還可以按照右邊界排序:

var eraseOverlapIntervals = function(intervals) {intervals.sort((a, b) => {return a[1] - b[1]})let count = 1let end = intervals[0][1]for(let i = 1; i < intervals.length; i++) {let interval = intervals[i]if(interval[0] >= end) {end = interval[1]count += 1}}return intervals.length - count
};


?763.劃分字母區間

題目鏈接:763.劃分字母區間

文檔講解:代碼隨想錄/劃分字母區間

視頻講解:視頻講解-劃分字母區間

狀態:已完成(1遍)

解題過程??

看到題目的第一想法

這題我的想法是首先要獲取字符串中每個字母的第一次出現索引和最后一次出現的索引,所以我寫了一個for循環用來更新每個字母在數組形式的哈希表中對應的每個小數組中開始和結束的索引。遍歷完了之后把得到的哈希數組去除沒出現過的字母的小數組,再將他們按照開始索引從小到大進行排序。這樣就得到了每個字母出現的區間。

然后就和上一道題一樣的流程了,不一樣的就是最后一部分切割的字符串長度沒辦法及時記錄,所以需要手動判斷一下當前如果是for循環的最后一個元素了,手動添加一下。

手搓代碼如下:

/*** @param {string} s* @return {number[]}*/
var partitionLabels = function (s) {let startEndHash = new Array(26).fill(null).map(() => [-1, -1]);for (let i = 0; i < s.length; i++) {let index = s[i].charCodeAt() - 97;if (startEndHash[index][0] == -1) {//記錄字符串中每個字母第一次出現的索引,和最后一次出現的索引startEndHash[index][0] = i;startEndHash[index][1] = i;} else {//已經出現過的只用改最后一次出現的索引就可以了startEndHash[index][1] = i;}}let newHash = startEndHash.filter((arr) => arr[0] !== -1);let sortedHash = newHash.sort((a, b) => a[0] - b[0]);let ans = [];for (let i = 1; i < sortedHash.length; i++) {if (sortedHash[i][0] < sortedHash[i - 1][1]) {sortedHash[i][1] = Math.max(sortedHash[i][1], sortedHash[i - 1][1]);//右端坐標取最大值,要包括所有出現的單個字母sortedHash[i][0] = sortedHash[i - 1][0];//左端坐標繼承下去if (i == sortedHash.length - 1) {//最后一串記不到ans.push(1 + sortedHash[i][1] - sortedHash[i][0]);}} else {ans.push(1 + sortedHash[i - 1][1] - sortedHash[i - 1][0]);//記錄上一個部分的長度if (i == sortedHash.length - 1) {//最后一串記不到ans.push(1 + sortedHash[i][1] - sortedHash[i][0]);}}}return ans;
};

提交成功!

?看完代碼隨想錄之后的想法?

我的解法是代碼隨想錄補充的和前面435思路一樣的解法,而這道題有更簡便的方法。

只需要記錄每個字母的最后一次出現的位置,因為在字符串從前往后的遍歷過程中就已經是按照第一次出現順序來遍歷了。然后每遍歷一個字母,看看它的最后一次出現位置是什么,如果一直遍歷到了最后一次出現的位置,那就說明可以切割了。

講解代碼如下:

/*** @param {string} s* @return {number[]}*/
var partitionLabels = function(s) {let hash = {}for(let i = 0; i < s.length; i++) {hash[s[i]] = i}let result = []let left = 0let right = 0for(let i = 0; i < s.length; i++) {right = Math.max(right, hash[s[i]])if(right === i) {result.push(right - left + 1)left = i + 1}}return result
};

總結

和射箭問題以及435的思路一樣確實可以解決這道題目,不過過程確實是太過復雜了。


56. 合并區間?

題目鏈接:56. 合并區間

文檔講解:代碼隨想錄/合并區間?

視頻講解:視頻講解-合并區間

狀態:已完成(1遍)

解題過程??

看到題目的第一想法

我的想法是首先還是將元素按照起始位置從小到大的順序排列。然后遍歷一個區間,更新當前重疊區間的最右端,如果新區間不和上一個區間重疊,則重新開始計算重疊區間。

手搓代碼如下:

/*** @param {number[][]} intervals* @return {number[][]}*/
var merge = function (intervals) {if(intervals.length == 1)return intervals;let sortedArr = intervals.sort((a, b) => a[0] - b[0]);let ans = [];let left = sortedArr[0][0], right = sortedArr[0][1];for (let i = 1; i < sortedArr.length; i++) {if (sortedArr[i][0] <= right) {//有重疊right = Math.max(sortedArr[i][1], right);if (i == sortedArr.length - 1) {let arr = [left, right];ans.push(arr);}} else {let arr = [left, right];ans.push(arr);left = sortedArr[i][0], right = sortedArr[i][1];if (i == sortedArr.length - 1) {let arr = [left, right];ans.push(arr);}}}return ans;
};

提交成功,沒有問題。?

?看完代碼隨想錄之后的想法?

大體思路和我差不多,小細節我還需注意,一個是每次添加進ans的數組不用left,right那么費事。還有對最后一個arr的添加不用if來判斷,直接在函數最后解決就行。

講解代碼如下:

/*** @param {number[][]} intervals* @return {number[][]}*/
var merge = function (intervals) {intervals.sort((a, b) => a[0] - b[0]);let prev = intervals[0]let result = []for(let i =0; i<intervals.length; i++){let cur = intervals[i]if(cur[0] > prev[1]){result.push(prev)prev = cur}else{prev[1] = Math.max(cur[1],prev[1])}}result.push(prev)return result
};

總結

一些細節確實還需要雕琢。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/14285.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/14285.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/14285.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

看上去好坑的運算符重載

#include <iostream> using namespace std; class MyInt {int nVal; public:MyInt(int n) { nVal n};MyInt & operator-(int n){ //運算符重載-nVal - n;return *this; } operator int() {return nVal;} //類型轉換函數};int Inc(int n){return n1; }int ma…

代碼隨想錄訓練營|一刷總結

代碼隨想錄一刷完成啦&#xff01;&#xff01;&#xff01; 自己曾經嘗試過刷力扣&#xff0c;但是卻不知道從何刷起、按什么順序刷題&#xff0c;直到遇到了卡哥、遇到了代碼隨想錄。研一上有著刷題的決心&#xff0c;但是卻沒有刷題的動力很難堅持下去&#xff0c;所以也就只…

【削水果game】

編寫一個完整的削水果游戲代碼是一個復雜的過程&#xff0c;涉及到游戲引擎的使用和游戲邏輯的編寫。在這里&#xff0c;我可以提供一個非常簡化的版本&#xff0c;使用Python和Pygame庫來創建一個基本的削水果游戲概念。請注意&#xff0c;這只是一個示例&#xff0c;用于展示…

Flutter Text導致A RenderFlex overflowed by xxx pixels on the right.

使用Row用來展示兩個Text的時候頁面出現如下異常,提示"A RenderFlex overflowed by xxx pixels on the right." The following assertion was thrown during layout: A RenderFlex overflowed by 4.8 pixels on the right.The relevant error-causing widget was:…

【仿RabbitMQ消息隊列項目day2】使用muduo庫中基于protobuf的應用層協議進行通信

一.什么是muduo? muduo庫是?個基于非阻塞IO和事件驅動的C高并發TCP網絡編程庫。 簡單來理解&#xff0c;它就是對原生的TCP套接字的封裝&#xff0c;是一個比socket編程接口更好用的編程庫。 二.使用muduo庫完成一個英譯漢翻譯服務 TranslateServer.hpp: #pragma once #in…

MyBatis中Where標簽:揭秘高效SQL構建的秘密

哈嘍&#xff0c;大家好&#xff0c;我是木頭左&#xff01; 理解Where標簽的基礎概念 在MyBatis中&#xff0c;<where>標簽是用于構建SQL查詢語句中的一個非常重要的元素。它允許你在一個動態的SQL語句中添加WHERE子句&#xff0c;而不需要擔心SQL語法錯誤或額外的逗號…

如何利用51建模網,實現3D模型線上展示和應用?

按照下面的步驟&#xff0c;在51建模網上傳3D模型&#xff0c;并編輯完成后&#xff0c;接下來就是如何讓這些3D模型得到更好的展示、傳播和應用。 一、3D內容快速分享與傳播 3D模型在51建模網上傳發布后&#xff0c;即可獲得一個可分享的鏈接和二維碼&#xff0c;直接分享給客…

20240520解決在Ubuntu20.04下編譯RK3588的Android12的SDK出現C2_GIT_BUILD_VERSION未定義的問題

20240520解決在Ubuntu20.04下編譯RK3588的Android12的SDK出現C2_GIT_BUILD_VERSION未定義的問題 2024/5/20 20:19 緣起&#xff1a;通過./repo/repo/repo sync -l得到的SDK正常&#xff0c;但是解壓縮之后的SDK卻出錯了&#xff01; 通過grep很容易發現有三個地方有&#xff0c…

深入分析 Android Activity (一)

深入分析 Android Activity (一) 接下來我們會深入分析 Activity 的一些高級特性和內部實現&#xff0c;包括窗口管理、生命周期管理、以及與 Fragment 的交互。 1. Activity 的窗口管理 在 Android 中&#xff0c;每個 Activity 都與一個 Window 相關聯。Window 是一個抽象…

如何選購尼龍輸送帶

尼龍輸送帶選購攻略&#xff1a;從入門到精通&#xff0c;一篇文章全搞定&#xff01; 在工業生產中&#xff0c;尼龍輸送帶作為關鍵的物流傳輸設備&#xff0c;其選擇和使用直接關系到生產效率和成本控制。面對市面上琳瑯滿目的尼龍輸送帶產品&#xff0c;如何選購到性價比高…

PointCloudLib 點云投影到XOY平面功能實現 C++版本

0.實現效果 左圖為原始點云,右圖為投影到XOY平面上的點云 將三維的點云投影到二維平面,方便處理一些二維輪廓方面的計算。 可以投影到空間中任意平面上。 1.算法原理 原理 點云投影是將三維空間中的點云數據映射到一個二維平面上的過程。這通常通過以下步驟實現: 確定投…

使用Golang開發一個HTTP客戶端請求命令行工具

什么是Golang Golang&#xff0c;也被稱為Go語言&#xff0c;是由Google開發的一種開源的編程語言。它于2007年開始設計&#xff0c;于2009年首次公開發布。Golang被設計成一種通用的編程語言&#xff0c;旨在提供簡單、高效和可靠的軟件開發方式。Golang具有靜態類型、垃圾回…

微服務實踐k8sdapr開發部署調用

前置條件 安裝docker與dapr: 手把手教你學Dapr - 3. 使用Dapr運行第一個.Net程序安裝k8s dapr 自托管模式運行 新建一個webapi無權限項目 launchSettings.json中applicationUrl端口改成5001,如下: "applicationUrl": "http://localhost:5001" //Wea…

c#實現視頻播放

在winform上實現視頻播放常用的控件時media player&#xff0c;vs工具欄初始狀態下沒有&#xff0c;需要我們到com組件中添加。添加完成后&#xff0c;把media player控件拖拽到一個Form窗口中。 在此實現遍歷某個文件夾下是否有mp4視頻&#xff0c;如果有則播放視頻。&#x…

BeautifulSoup4通過lxml使用Xpath,以及獲取(定位)元素和其文本或者屬性

環境&#xff1a;win10&#xff0c;python3.8.10 首先需要安裝&#xff1a;beautifulsoup4&#xff0c;lxml 使用命令&#xff1a; pip38 install beautifulsoup4 pip38 install lxml 安裝完畢后查看一下&#xff1a; 寫代碼&#xff1a; from bs4 import BeautifulSoup …

Go 圖像處理

Golang中的image包提供了基本的圖像類型、顏色模型、以及用于處理圖像的各種函數和接口。 常用類型與接口 image.Image 接口 這是Go語言中處理圖像的核心接口&#xff0c;定義了所有圖像必須實現的方法&#xff1a; type Image interface {// Bounds returns the domain for…

rocketmq 學習二 基本概念

教程&#xff1a;基本概念 | RocketMQ 視頻教程 https://www.bilibili.com/video/BV1d5411y7UW?vd_sourcef1bd3b5218c30adf0a002c8c937e0a27 版本&#xff1a;5.0 一 基本概念 1.1 生產者/Producer 1.1.1 定義 消息發布者。是構建并傳輸消息到服務端的運行實體。…

異眾比率(variation ratio)

異眾比率&#xff08;variation ratio&#xff09;是指非眾數組的頻數占總頻數的比率&#xff0c;其計算公式為: 其中&#xff0c;為眾數組的頻數。 異眾比率主要用于衡量眾數對一組數據的代表程度。異眾比率越大&#xff0c;說明非眾數組的頻數占總頻數的比重越大&#xff0…

harbor 認證

Harbor 認證過程 Harbor以 Docker Registry v2認證為基礎&#xff0c;添加上一層權限保護。1.v2 集成了一個安全認證的功能&#xff0c;將安全認證暴露給外部服務&#xff0c;讓外部服務去實現2.強制用戶每次Docker pull/push請求都要帶一個合法的Token&#xff0c;Registry會…

python的requests爬蟲模塊使用代理ip方法---集合

形式一 import requests proxies {http:128.3.74.224:2890,https:128.3.74.224:2890} ip requests.get(http://httpbin.org/ip,proxiesproxies) print(ip.text)形式二 形式一不行的情況下&#xff0c;試試形式二 import requests proxies {http:http://127.0.0.1:7890,http…