国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

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

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

[[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

2024-07-29 08:28:00

模型AI

2016-04-05 10:12:58

HiveSQLHadoop

2017-09-27 13:42:42

數據庫MySQL斷電恢復

2009-06-17 14:36:02

學習Java心得

2009-06-25 13:59:59

java認證FileFilter

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技術棧公眾號

日韩毛片网站| 丝袜亚洲另类欧美综合| 国产人与zoxxxx另类91| av不卡免费在线观看| 俺去亚洲欧洲欧美日韩| 国产日韩第一页| 最新国产精品久久久| 秋霞午夜理伦电影在线观看| 国产欧美精品一区二区色综合朱莉 | 激情成人在线视频| 国产精品入口免费视频一| av一区在线观看| 黄色日韩网站视频| 91超碰中文字幕久久精品| 九色国产在线观看| 国产精品入口麻豆九色| 麻豆精品视频| 亚洲午夜免费| 国产视频在线一区二区| 你懂的在线观看| 欧美97人人模人人爽人人喊视频| 久久精品一区二区国产| 2020日本不卡一区二区视频| 永久免费毛片在线播放不卡| 在线看片你懂得| 欧美三级电影在线看| 日韩av自拍| 欧美一级一区二区| 美女尤物在线视频| 亚洲精美色品网站| 日韩欧美一区二区三区免费观看 | 在线看日本不卡| 97超碰国产一区二区三区| 91精品婷婷国产综合久久性色 | 日韩久久精品电影| 99久久99九九99九九九| 性欧美xxxx| 久久精品高清| 久久综合伊人77777麻豆| 狠狠色丁香九九婷婷综合五月| 大陆av在线播放| 亚洲人精品一区| 国产午夜视频在线观看| 亚洲美女动态图120秒| 亚洲日本va中文字幕| 国产又爽又黄的激情精品视频 | 国产精品你懂的| 欧美日韩免费做爰大片| 精品处破学生在线二十三| 狠狠久久综合| 91精品久久久久久综合乱菊 | 五月婷婷之综合激情| 久久成人免费视频| 日韩久久久久久久| 日韩理论电影大全| 久久国产精品久久国产精品| 妞干网视频在线观看| 亚洲已满18点击进入在线看片 | 亚洲欧美日韩精品久久| 2020色愉拍亚洲偷自拍| 亚洲国产成人精品视频| 欧美性久久久久| 99久久综合色| siro系绝美精品系列| 欧美日韩中文在线| av在线播放网站| 中文字幕精品久久久久| 亚洲开心激情| 国产一区二区在线观看免费播放| 国产精品亚洲综合一区在线观看| 麻豆映画在线观看| 国产精品久久久久久久久免费樱桃| 中出福利视频| 中文字幕不卡在线视频极品| 亚洲国产裸拍裸体视频在线观看乱了中文| 欧美日韩一区二区三区在线观看免| 亚洲精品护士| 九九热精品视频国产| 爱福利在线视频| 亚洲欧美日韩一区二区在线| 欧美午夜精彩| 人妻熟妇乱又伦精品视频| 91 com成人网| 国产精品一级在线观看| 国产精品日韩欧美一区二区三区 | 国产中文字幕在线观看| 亚洲天堂av综合网| 99久久99热这里只有精品| 久久久99精品视频| 欧美性一级生活| 免费看久久久| 日韩成人三级视频| 91精品在线观看入口| 一区二区三区日本久久久| 91大学生片黄在线观看| 91国内精品野花午夜精品| 亚洲一区 二区| 中文字幕一区二区三区四区五区六区| 亚洲国产精品久久艾草纯爱| 日韩有吗在线观看| 成人午夜视频免费观看| 日韩精品一区二区在线观看| 91精品国产乱码久久久久久| 羞羞免费视频| 欧美成人精品三级在线观看 | 色综合桃花网| 国产二区一区| 亚洲香肠在线观看| 超碰成人免费| 91丨porny丨探花| 日韩av在线免费播放| 亚洲视频成人| 黄色电影免费在线看| 日韩美女福利视频| 中文字幕av在线一区二区三区| av免费网站观看| 亚洲精品av在线| 狠狠色狠狠色综合| 欧美一性一交| 91黑丝在线| 日韩久久精品电影| 欧美日韩三级| 亚洲男人天堂| 国产精品成久久久久三级| 99久久精品国产麻豆演员表| 波多野一区二区| 免费成人av网站| 欧美性xxxxx| 色狮一区二区三区四区视频| 先锋在线亚洲| 91高清免费视频| 《视频一区视频二区| eeuss国产一区二区三区四区| 亚洲精品久久久久久久蜜桃臀| 日韩电影中文字幕av| 美国一区二区三区在线播放 | 日韩国产欧美三级| 欧美激情午夜| 免费在线一区二区| 欧美一区二区三区四区五区| 尤物在线精品| 成人日韩欧美| 在线亚洲美日韩| 影音先锋欧美精品| 99久久免费视频.com| 亚洲精品国产九九九| 男捅女免费视频| 国产日韩欧美中文| 欧美日韩一二区| 蜜桃一区二区三区在线观看| 久久野战av| 欧美精品成人网| 国产成人一区二区| 在线看国产日韩| 秋霞电影一区二区| 日韩另类视频| 成年人黄色电影| 国产伦一区二区三区色一情| 日韩欧美中文一区二区| 日本aⅴ亚洲精品中文乱码| 日本不卡一二三| 天堂在线资源视频| 91精品视频在线| 欧美精品高清视频| 国产精品996| 欧美有码在线| 午夜免费福利在线观看| 麻豆视频传媒入口| 久久久久女教师免费一区| 亚洲福利电影网| 日韩av中文字幕一区二区| 91免费看蜜桃| 日韩精品一区二区三区蜜臀 | 欧美另类视频在线| 永久免费看mv网站入口亚洲| 国产精品无码永久免费888| 91蜜臀精品国产自偷在线| 国产黄大片在线观看画质优化| avav在线播放| 国产精品视频1区| 亚洲国产精品字幕| 亚洲欧洲性图库| 国产精品五区| 亚洲精品一区二区三区在线| 国产午夜视频在线观看| 老司机激情视频| 成人激情av在线| 国产一区二区三区视频在线观看| 亚洲视频每日更新| 日韩av中文字幕一区二区| 美女福利一区| 182在线视频观看| 免费黄视频网站| 在线精品亚洲一区二区| 97久久精品人搡人人玩| 欧美日韩精品一区二区| 久久这里只有精品6| 黑人一区二区| 成人免费直播在线| 欧美人动性xxxxz0oz|