成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

單調棧一點小心得 | 用最簡單的動圖和例題解釋一下

開發 前端
單調棧是一種預處理技術。用 的時間處理一個長度為 的序列,會得到這 個元素的最相鄰的比自己小的元素 / 比自己大的元素 / 以該元素結尾的遞增或遞減子序列長度等。

[[414639]]

本文轉載自微信公眾號「Piper蛋窩」,作者Piper蛋 。轉載本文請聯系Piper蛋窩公眾號。

上上周 力扣雙周賽 T4[1] 和 Acwing 第 9 場周賽最后一題[2] 的考點竟然都是單調棧。

對單調棧理解不透徹,當時沒想到。

其實單調棧題目的特征很明顯。

一般來講,單調棧題目需要就數學關系進行分析,比如:

  • 我們需要尋找一個非凹子序列
  • 即我們需要尋找兩個子序列,一個在左邊單調增,一個在右邊單調減,因此用兩個單調棧分別從左往右和從右往左預處理序列

非凹的序列應該只有這三種

單調棧有什么特性呢?我該怎么想到:「喔,這個問題可以用單調棧來解決呢?」我總結了一下:

遍歷到 i 時,總會把 i 推入棧,總會保證棧頂到棧底是降序的。因此在把 i 入棧前,從棧頂開始,把比 i 高(大于等于)的都 pop 出來。

即,單調棧是一種預處理技術。用 的時間處理一個長度為 的序列,會得到這 個元素的最相鄰的比自己小的元素 / 比自己大的元素 / 以該元素結尾的遞增或遞減子序列長度等。

這非常 amazing ,按理說,想要得到 個信息,起碼要用 或者 的時間吧。

搞個動圖和經典例題解釋一下。

我們有一個長度為 5 的序列:3 4 2 7 5 ,我們希望找到每一個數左邊的第一個比自己小的數。我們知道分別是:沒有 3 沒有 2 2 。如何設計一個算法讓計算機自動找到這些數呢?見下面的動圖。

因此咱們可以總結出其性質如下。

例題:尋找左邊最近的比自己小的數

來源:AcWing在線題庫[3]

  • 給定一個長度為 N 的整數數列,輸出每個數左邊第一個比它小的數,如果不存在則輸出 ?1。

輸入格式

  • 第一行包含整數 N,表示數列長度。
  • 第二行包含 N 個整數,表示整數數列。

輸出格式

  • 共一行,包含 N 個整數,其中第 i 個數表示第 i 個數的左邊第一個比它小的數,如果不存在則輸出 ?1。

分析:

  • 首先想到兩層循環,暴力做法;接下來想哪里可以優化(類似雙指針的思路)
  • 注意一個性質,如果 i < j ,且 a[i] >= a[j] ,那么我們之后都沒必要管 i 了,因為 j 比 i 更加靠右,且值更小;后面的數向左搜索的過程中,碰到 j 覺得不行(還沒 a[j] 大呢),碰到 i 更不會覺得行了(更不會有 a[i] 大)
  • 用單調棧實現
  1. #include <iostream> 
  2.  
  3. using namespace std; 
  4.  
  5. const int N = 1e5 + 10; 
  6.  
  7. int stk[N], tt; 
  8.  
  9. int main() 
  10.     int n, x; 
  11.     cin >> n; 
  12.      
  13.     for (int i = 0; i < n; i ++) 
  14.     { 
  15.         cin >> x; 
  16.         while (tt && stk[tt] >= x) tt --; 
  17.         if (tt) cout << stk[tt] << " "
  18.         else cout << -1 << " "
  19.          
  20.         stk[++ tt] = x; 
  21.     } 
  22.      
  23.     return 0; 

參考資料

[1]力扣雙周賽 T4: https://leetcode-cn.com/problems/number-of-visible-people-in-a-queue/

[2]Acwing 第 9 場周賽最后一題: https://www.acwing.com/problem/content/3783/

[3]AcWing在線題庫: https://www.acwing.com/problem/content/832/

 

責任編輯:武曉燕 來源: Piper蛋窩
相關推薦

2021-08-02 07:59:21

單調棧題目

2020-07-06 08:00:26

MySQL程序員SQL

2021-08-28 09:06:11

Dubbo架構服務

2025-02-28 09:14:09

JavaNIO機制

2011-01-18 13:45:58

2020-08-13 08:43:24

TCP固定窗口滑動窗口

2020-02-28 09:09:51

閉包函數作用域

2013-01-08 10:06:43

創業創業方法

2023-05-22 10:09:21

FlexboxCSS3

2016-04-05 10:12:58

HiveSQLHadoop

2024-07-29 08:28:00

模型AI

2017-09-27 13:42:42

數據庫MySQL斷電恢復

2009-06-25 13:59:59

java認證FileFilter

2009-06-17 14:36:02

學習Java心得

2009-11-17 11:14:25

Oracle擴展

2019-01-02 11:22:27

HTTPFTPSMTP

2025-06-25 10:17:48

2021-04-21 21:06:11

數據結構

2018-03-28 15:07:16

測試環境vagrant

2018-08-24 16:50:09

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 成人高潮片免费视频欧美 | 网色 | 97精品一区二区 | 欧美一区永久视频免费观看 | 久久久这里都是精品 | 亚洲一区电影 | 国产女人精品视频 | 国产免费拔擦拔擦8x高清 | 日韩精品一区二区三区在线播放 | 国产精品日韩 | 日本黄色影片在线观看 | 精品一区二区电影 | 作爱视频免费观看 | 欧美成人精品激情在线观看 | 热久久久 | 国产96在线 | 一区二区三区高清不卡 | 国产成人久久精品一区二区三区 | 成人在线看片 | 在线视频国产一区 | 亚洲精品无人区 | 日韩一二三区视频 | 亚洲高清三级 | 精品1区2区3区4区 | 午夜性色a√在线视频观看9 | 成人福利在线 | 黄色网址免费在线观看 | 日韩a在线 | 成人免费高清 | 国产精品日韩 | 日韩精品网站 | 色综合区| 99re66在线观看精品热 | 亚洲天堂av网 | 久亚州在线播放 | 成人av一区二区三区 | 欧美在线一区二区三区 | 秋霞电影院午夜伦 | 7777在线| 欧美日韩成人在线 | 免费在线观看一区二区 |