代碼隨想錄算法訓練營 --- 第五十九天

今天同樣是單調棧,第二題很重要。

第一題:

簡介:

本題可以說和上一題很是相似,只是有一點不同,數組是循環的。本題有兩種巧妙地解法,都不難。

第一種方法(也是第一個想出來的方法):

拼接數組,我們將兩個相同的nums數組進行拼接這樣我們就可以保證第一個nums數組進行了循環的遍歷。此方法容易相處但是有很多弊端:例如浪費空間很多,也做了很多多余的操作,我們拼接數組后,還要剪切數組等等。

代碼實現:
vector<int> nextGreaterElements(vector<int>& nums) {stack<int> str;vector<int> path(nums.size()*2,0);vector<int> result(nums.size()*2,-1);str.push(0);int k=0;for(int i=0;i<nums.size()*2;i++){if(k==nums.size()) k=0;path[i] = nums[k];k++;}for(int i=1;i<path.size();i++){if(path[i]>path[str.top()]){while(!str.empty()&&path[i]>path[str.top()]){result[str.top()] = path[i];str.pop();}str.push(i);}else if(path[i] == path[str.top()]){str.push(i);}else{str.push(i);}}for(int i=0;i<nums.size();i++){result.pop_back();}return result;}
第二種方法(很巧妙的實現了循環遍歷數組):

此種方法我們通過 [i%nums.size()]來實現我們重復遍歷數組的目的。

代碼實現:?
 vector<int> nextGreaterElements(vector<int>& nums) {vector<int> result(nums.size(), -1);if (nums.size() == 0) return result;stack<int> st;st.push(0);for (int i = 1; i < nums.size() * 2; i++) { // 模擬遍歷兩邊nums,注意一下都是用i % nums.size()來操作if (nums[i % nums.size()] < nums[st.top()]) st.push(i % nums.size());else if (nums[i % nums.size()] == nums[st.top()]) st.push(i % nums.size()); else {while (!st.empty() && nums[i % nums.size()] > nums[st.top()]) {result[st.top()] = nums[i % nums.size()];st.pop();}st.push(i % nums.size());}}return result;}

第二題:

簡介:

本題是面試中考的概率很高的一題。

本題共有三種方法

暴力破解法

暴力法的重點在于如何求出單列的水的體積例如:

列4 左側最高的柱子是列3,高度為2(以下用lHeight表示)。

列4 右側最高的柱子是列7,高度為3(以下用rHeight表示)。

列4 柱子的高度為1(以下用height表示)

那么列4的雨水高度為 列3和列7的高度最小值減列4高度,即: min(lHeight, rHeight) - height。

列4的雨水高度求出來了,寬度為1,相乘就是列4的雨水體積了。

此時求出了列4的雨水體積。

我們遍歷每列然后將結果相加也就是最后的答案。

時間復雜度為O(n)

代碼實現:
 int trap(vector<int>& height) {int sum = 0;for (int i = 0; i < height.size(); i++) {// 第一個柱子和最后一個柱子不接雨水if (i == 0 || i == height.size() - 1) continue;int rHeight = height[i]; // 記錄右邊柱子的最高高度int lHeight = height[i]; // 記錄左邊柱子的最高高度for (int r = i + 1; r < height.size(); r++) {if (height[r] > rHeight) rHeight = height[r];}for (int l = i - 1; l >= 0; l--) {if (height[l] > lHeight) lHeight = height[l];}int h = min(lHeight, rHeight) - height[i];if (h > 0) sum += h;}return sum;}
雙指針法

思路與暴力解法一樣,只是我們在代碼實現上有所不同,我們通過兩個數組將左邊柱子最大高度和右邊柱子最大高度都記錄下來。然后我們在遍歷時就省下了很多時間。時間復雜度O(n)

代碼實現:
  int trap(vector<int>& height) {if (height.size() <= 2) return 0;vector<int> maxLeft(height.size(), 0);vector<int> maxRight(height.size(), 0);int size = maxRight.size();// 記錄每個柱子左邊柱子最大高度maxLeft[0] = height[0];for (int i = 1; i < size; i++) {maxLeft[i] = max(height[i], maxLeft[i - 1]);}// 記錄每個柱子右邊柱子最大高度maxRight[size - 1] = height[size - 1];for (int i = size - 2; i >= 0; i--) {maxRight[i] = max(height[i], maxRight[i + 1]);}// 求和int sum = 0;for (int i = 0; i < size; i++) {int count = min(maxLeft[i], maxRight[i]) - height[i];if (count > 0) sum += count;}return sum;}
單調棧法

單調棧發與前兩個解法不同,前兩個解法是按列來計算,此解法為按行來計算。后面便利的過程建議去跟卡哥的視頻走一趟就明白了,或者自己模擬過程。

代碼實現:
  int trap(vector<int>& height) {if (height.size() <= 2) return 0; // 可以不加stack<int> st; // 存著下標,計算的時候用下標對應的柱子高度st.push(0);int sum = 0;for (int i = 1; i < height.size(); i++) {if (height[i] < height[st.top()]) {     // 情況一st.push(i);} if (height[i] == height[st.top()]) {  // 情況二st.pop(); // 其實這一句可以不加,效果是一樣的,但處理相同的情況的思路卻變了。st.push(i);} else {                                // 情況三while (!st.empty() && height[i] > height[st.top()]) { // 注意這里是whileint mid = st.top();st.pop();if (!st.empty()) {int h = min(height[st.top()], height[i]) - height[mid];int w = i - st.top() - 1; // 注意減一,只求中間寬度sum += h * w;}}st.push(i);}}return sum;}

總結:

?單調棧的題目從我的感覺來講就是明白運行過程,理清思路,進行遍歷,然后考慮好棧是遞增還是遞減,然后基本上大部分題的基礎思路就出來了。繼續加油!

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

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

相關文章

創建自定義Docker鏡像:一步步指南

當創建自定義Docker鏡像時&#xff0c;Dockerfile是關鍵的一環。這篇博客將詳細介紹如何編寫一個Dockerfile&#xff0c;其中包含創建自定義應用程序所需的步驟和示例。讓我們開始吧&#xff1a; 創建自定義Docker鏡像&#xff1a;一步步指南 1. 了解Dockerfile Dockerfile是…

我的acer電腦U盤裝系統前BIOS設置及裝系統過程中的操作

1、開機長按F2進入BIOS設置 2、使能F12 3、調整boot順序&#xff0c;使USB啟動的優先級最高 4、按F10保存退出 5、插入U盤開機&#xff0c;boot選擇界面無需操作&#xff0c;等待幾秒&#xff0c;默認進入U盤系統 由于既使能了F12&#xff0c;又將U盤的優先級進調整到了最高&…

OpenVINS學習1——數據集配置與運行

前言 OpenVINS是基于MSCKF的開源VIO算法&#xff0c;有非常詳細的官網文檔可以學習使用&#xff0c;將來一段時間的主要實踐工作&#xff0c;就是深度掌握這份開源代碼。 https://docs.openvins.com/ 一、環境配置與Euroc數據集運行 我的環境是Ubuntu20.04&#xff0c;ROS1&a…

vue3中實現el-tree通過ctrl或shift批量選擇節點并高亮展示

一、看效果&#xff1a; 按住ctrl鍵實現單個多選 按住shift實現區間范圍多選 二、代碼&#xff1a; vue頁面 <template><el-treeclass"w100%":data"$.treeData"ref"treeTab…

Unity中Batching優化的靜態合批

文章目錄 前言一、靜態合批的規則1、模型使用同一個材質2、勾選靜態合批3、對于靜態合批后的Mesh頂點總數&#xff0c;不超過2^16^即可以使用同一批次&#xff0c;超過則會開啟一個新的批次4、對與使用同一材質的不同模型間&#xff0c;紋理貼圖的問題&#xff0c;我們可以通過…

數據可視化工具選擇:功能、易用性與安全性

作為一名數據可視化大屏設計師&#xff0c;我深知選擇一款合適的數據可視化工具對于提高工作效率和呈現效果的重要性。下面&#xff0c;我將從真正對我們數據可視化大屏設計師有用的角度為大家介紹選擇數據可視化工具的一些必要條件和要求。 1. 功能強大與靈活定制 首先&…

高并發場景下的httpClient使用優化技巧

1. 背景 我們有個業務&#xff0c;會調用其他部門提供的一個基于http的服務&#xff0c;日調用量在千萬級別。使用了httpclient來完成業務。之前因為qps上不去&#xff0c;就看了一下業務代碼&#xff0c;并做了一些優化&#xff0c;記錄在這里。 先對比前后&#xff1a;優化…

如何做好口譯服務,同傳和交傳哪個服務好

隨著中國經濟的蓬勃發展和綜合實力的不斷增強&#xff0c;中國與世界各國的交流也日益頻繁。口譯作為對外交流的橋梁與紐帶&#xff0c;需求量與日俱增&#xff0c;其重要性不言而喻。那么&#xff0c;如何做好口譯服務呢&#xff1f;是同傳還是交傳更好呢&#xff1f; 業內專家…

滲透測試工具AWVS的全面解析

在當今的數字化時代&#xff0c;網絡安全已經成為了企業和個人必須關注的重要問題。為了確保網絡的安全&#xff0c;我們需要使用各種工具和技術進行檢測和防護。其中&#xff0c;滲透測試是一種非常重要的方法&#xff0c;它可以幫助我們發現網絡中的安全漏洞&#xff0c;并采…

機器人純阻抗控制接觸剛性環境

問題描述 在機器人學中&#xff0c;阻抗控制是一種常用的控制策略&#xff0c;用于管理機器人在與環境交互時的運動和力。阻抗控制背后的關鍵概念是將環境視為導納&#xff0c;而將機器人視為阻抗。 純阻抗控制接觸剛性環境時&#xff0c;機器人的行為方式主要受其阻抗參數的…

表單小程序作用體現在哪

表單的用途非常廣泛&#xff0c;它是線上收集信息或用戶預約/需求服務的重要方式&#xff0c;對商家來說如今線上平臺非常多&#xff0c;生意開展的形式也越來越多&#xff0c;比如常見的預約、報名、收款、產品支付等都可以通過表單實現。 接下來啊讓我們看看通過【雨科】平臺…

家用智能門鎖——智能指紋鎖方案

智能指紋鎖產品功能&#xff1a; 1&#xff1a;指紋識別技術&#xff1a;光學傳感器、半導體傳感器或超聲波傳感器等。 2&#xff1a;指紋容量&#xff1a;智能指紋鎖可以存儲的指紋數量&#xff0c;通常在幾十到幾百個指紋之間。 3&#xff1a;解鎖時間&#xff1a;指紋識別和…

【力扣100】8.找到字符串中所有字母異位詞

添加鏈接描述 class Solution:def findAnagrams(self, s: str, p: str) -> List[int]:sildingstrresult[]p.join(sorted(p))for i in range(len(s)):if len(sildingstr)<len(p):sildingstrsildingstrs[i]# print(sildingstr)if len(sildingstr)len(p):sort_sildingstr.j…

Android開發常用工具類集合

目錄 DownloadGradleAPIsActivity 相關 -> ActivityUtils.java -> DemoAdaptScreen 相關 -> AdaptScreenUtils.java -> DemoApp 相關 -> AppUtils.java -> Demo欄相關 -> BarUtils.java -> Demo亮度相關 -> BrightnessUtils.java -> DemoBus 相關…

身份認證技術

身份認證是對系統的用戶進行有效性、真實性驗證。 1&#xff0e;口令認證方式 使用口令認證方式&#xff0c;用戶必須具有一個唯一的系統標識&#xff0c;并且保證口令在系統的使用和存儲過程中是安全的&#xff0c;同時口令在傳輸過程中不能被竊取、替換。另外特別要注意的是在…

解決:During handling of the above exception, another exception occurred

解決&#xff1a;During handling of the above exception, another exception occurred 文章目錄 解決&#xff1a;During handling of the above exception, another exception occurred背景報錯問題報錯翻譯報錯位置代碼報錯原因解決方法參考內容&#xff1a;今天的分享就到…

numpy數據讀取保存及速度測試

目錄 數據保存及讀取 速度比對測試 數據保存及讀取 代碼示例&#xff1a; # 導入必要的庫 import numpy as np # 生成測試數據 arr_disk np.arange(8) # 打印生成能的數據 print(arr_disk) # numpy保存數據到本地 np.save("arr_disk", arr_disk) # 加載本地數據…

排序算法-插入/希爾排序

1 插入排序 1.1基本思想&#xff1a; 直接插入排序是一種簡單的插入排序法&#xff0c;其基本思想是&#xff1a;把待排序的記錄按其關鍵碼值的大小逐個插入到一個已經排好序的有序序列中&#xff0c;直到所有的記錄插入完為止&#xff0c;得到一個新的有序序列 。 1.2直…

CentOS7.0 下rpm安裝MySQL5.5.60

下載 下載路徑: MySQL :: Download MySQL Community Server -->looking for the latest GA version-->5.5.60 此壓縮包中有多個rpm包 有四個不是必須的,只需安裝這三個 MySQL-server-5.5.60-1.el6.x86_64 MySQL-devel-5.5.60-1.el6.x86_64 MySQL-client-5.5.60-1.el6.x8…

pymysql insert dataframe 遇到 nan 值

def get_db_conn():"""MYSQL連接"""host Config.MYSQL["host"]pwd Config.MYSQL["pwd"]user Config.MYSQL["user"]port Config.MYSQL["port"]database Config.MYSQL["database"]conn p…