精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

擺動序列,也能貪心

開發 前端
如果連續數字之間的差嚴格地在正數和負數之間交替,則數字序列稱為擺動序列。第一個差(如果存在的話)可能是正數或負數。少于兩個元素的序列也是擺動序列。

[[434526]]

擺動序列

力扣題目鏈接:https://leetcode-cn.com/problems/wiggle-subsequence

如果連續數字之間的差嚴格地在正數和負數之間交替,則數字序列稱為擺動序列。第一個差(如果存在的話)可能是正數或負數。少于兩個元素的序列也是擺動序列。

例如, [1,7,4,9,2,5] 是一個擺動序列,因為差值 (6,-3,5,-7,3) 是正負交替出現的。相反, [1,4,7,2,5] 和 [1,7,4,5,5] 不是擺動序列,第一個序列是因為它的前兩個差值都是正數,第二個序列是因為它的最后一個差值為零。

給定一個整數序列,返回作為擺動序列的最長子序列的長度。通過從原始序列中刪除一些(也可以不刪除)元素來獲得子序列,剩下的元素保持其原始順序。

示例 1:

  • 輸入: [1,7,4,9,2,5]
  • 輸出: 6
  • 解釋: 整個序列均為擺動序列。

示例 2:

  • 輸入: [1,17,5,10,13,15,10,5,16,8]
  • 輸出: 7
  • 解釋: 這個序列包含幾個長度為 7 擺動序列,其中一個可為[1,17,10,13,10,16,8]。

示例 3:

  • 輸入: [1,2,3,4,5,6,7,8,9]
  • 輸出: 2

思路1(貪心解法)

本題要求通過從原始序列中刪除一些(也可以不刪除)元素來獲得子序列,剩下的元素保持其原始順序。

相信這么一說嚇退不少同學,這要求最大擺動序列又可以修改數組,這得如何修改呢?

來分析一下,要求刪除元素使其達到最大擺動序列,應該刪除什么元素呢?

用示例二來舉例,如圖所示:

擺動序列

局部最優:刪除單調坡度上的節點(不包括單調坡度兩端的節點),那么這個坡度就可以有兩個局部峰值。

整體最優:整個序列有最多的局部峰值,從而達到最長擺動序列。

局部最優推出全局最優,并舉不出反例,那么試試貪心!

(為方便表述,以下說的峰值都是指局部峰值)

實際操作上,其實連刪除的操作都不用做,因為題目要求的是最長擺動子序列的長度,所以只需要統計數組的峰值數量就可以了(相當于是刪除單一坡度上的節點,然后統計長度)

這就是貪心所貪的地方,讓峰值盡可能的保持峰值,然后刪除單一坡度上的節點。

本題代碼實現中,還有一些技巧,例如統計峰值的時候,數組最左面和最右面是最不好統計的。

例如序列[2,5],它的峰值數量是2,如果靠統計差值來計算峰值個數就需要考慮數組最左面和最右面的特殊情況。

所以可以針對序列[2,5],可以假設為[2,2,5],這樣它就有坡度了即preDiff = 0,如圖:

.擺動序列1

針對以上情形,result初始為1(默認最右面有一個峰值),此時curDiff > 0 && preDiff <= 0,那么result++(計算了左面的峰值),最后得到的result就是2(峰值個數為2即擺動序列長度為2)

C++代碼如下(和上圖是對應的邏輯):

  1. class Solution { 
  2. public
  3.     int wiggleMaxLength(vector<int>& nums) { 
  4.         if (nums.size() <= 1) return nums.size(); 
  5.         int curDiff = 0; // 當前一對差值 
  6.         int preDiff = 0; // 前一對差值 
  7.         int result = 1;  // 記錄峰值個數,序列默認序列最右邊有一個峰值 
  8.         for (int i = 0; i < nums.size() - 1; i++) { 
  9.             curDiff = nums[i + 1] - nums[i]; 
  10.             // 出現峰值 
  11.             if ((curDiff > 0 && preDiff <= 0) || (preDiff >= 0 && curDiff < 0)) { 
  12.                 result++; 
  13.                 preDiff = curDiff; 
  14.             } 
  15.         } 
  16.         return result; 
  17.     } 
  18. }; 

時間復雜度O(n) 空間復雜度O(1)

思路2(動態規劃)

考慮用動態規劃的思想來解決這個問題。

很容易可以發現,對于我們當前考慮的這個數,要么是作為山峰(即nums[i] > nums[i-1]),要么是作為山谷(即nums[i] < nums[i - 1])。

  • 設dp狀態dp[i][0],表示考慮前i個數,第i個數作為山峰的擺動子序列的最長長度
  • 設dp狀態dp[i][1],表示考慮前i個數,第i個數作為山谷的擺動子序列的最長長度

則轉移方程為:

  • dp[i][0] = max(dp[i][0], dp[j][1] + 1),其中0 < j < i且nums[j] < nums[i],表示將nums[i]接到前面某個山谷后面,作為山峰。
  • dp[i][1] = max(dp[i][1], dp[j][0] + 1),其中0 < j < i且nums[j] > nums[i],表示將nums[i]接到前面某個山峰后面,作為山谷。

初始狀態:

由于一個數可以接到前面的某個數后面,也可以以自身為子序列的起點,所以初始狀態為:dp[0][0] = dp[0][1] = 1。

C++代碼如下:

  1. class Solution { 
  2. public
  3.     int dp[1005][2]; 
  4.     int wiggleMaxLength(vector<int>& nums) { 
  5.         memset(dp, 0, sizeof dp); 
  6.         dp[0][0] = dp[0][1] = 1; 
  7.  
  8.         for (int i = 1; i < nums.size(); ++i) 
  9.         { 
  10.             dp[i][0] = dp[i][1] = 1; 
  11.  
  12.             for (int j = 0; j < i; ++j) 
  13.             { 
  14.                 if (nums[j] > nums[i]) dp[i][1] = max(dp[i][1], dp[j][0] + 1); 
  15.             } 
  16.  
  17.             for (int j = 0; j < i; ++j) 
  18.             { 
  19.                 if (nums[j] < nums[i]) dp[i][0] = max(dp[i][0], dp[j][1] + 1); 
  20.             } 
  21.         } 
  22.         return max(dp[nums.size() - 1][0], dp[nums.size() - 1][1]); 
  23.     } 
  24. }; 
  • 時間復雜度O(n^2)
  • 空間復雜度O(n)

進階

可以用兩棵線段樹來維護區間的最大值

每次更新dp[i][0],則在tree1的nums[i]位置值更新為dp[i][0]

每次更新dp[i][1],則在tree2的nums[i]位置值更新為dp[i][1]

則dp轉移方程中就沒有必要j從0遍歷到i-1,可以直接在線段樹中查詢指定區間的值即可。

  • 時間復雜度O(nlogn)
  • 空間復雜度O(n)

總結

貪心的題目說簡單有的時候就是常識,說難就難在都不知道該怎么用貪心。

本題大家如果要去模擬刪除元素達到最長擺動子序列的過程,那指定繞里面去了,一時半會拔不出來。

而這道題目有什么技巧說一下子能想到貪心么?

其實也沒有,類似的題目做過了就會想到。

 

此時大家就應該了解了:保持區間波動,只需要把單調區間上的元素移除就可以了。

 

責任編輯:武曉燕 來源: 代碼隨想錄
相關推薦

2009-01-18 09:19:00

DHCPVlANIP

2011-07-13 10:32:09

開源

2015-10-20 10:57:22

無線充電無線技術

2019-04-17 18:04:10

網卡虛擬化網絡設備

2012-12-20 09:41:49

JVMJava

2022-02-10 08:07:41

機器學習低代碼開發

2009-12-25 10:07:38

Linux系統多點觸摸

2012-12-20 09:15:29

JVMJVM平臺JVM技術

2014-06-24 09:24:24

密碼身份驗證

2021-12-27 07:45:30

CSS 技巧煙霧效果

2021-03-26 10:02:29

PythonVIP視頻看電影

2023-06-26 07:51:48

2018-01-26 09:01:16

對象存儲Java

2019-07-09 08:44:00

DeepfakeGAN人工智能

2010-09-02 17:31:42

VisualStudi微軟flash

2025-04-14 00:00:00

MCPjson 信息地理編碼

2017-08-14 16:36:23

ASActivity內存

2025-02-10 11:11:47

2021-08-04 09:00:53

Python數據庫Python基礎

2015-07-29 14:19:24

點贊
收藏

51CTO技術棧公眾號

免费看黄色一级大片| 国产精品二区三区| 神马久久精品综合| 国产一区在线电影| 在线观看亚洲成人| 国风产精品一区二区| 亚州视频一区二区三区| 久久精品72免费观看| 久久久久免费视频| 欧美性受xxxx黑人| 99re8这里有精品热视频8在线| 欧美日韩性生活视频| 一区二区av| 日本在线视频1区| 国产精品白丝jk黑袜喷水| 97香蕉超级碰碰久久免费的优势| 日本视频在线免费| 欧美aaaaa级| 欧美一区二区三区视频免费播放| 黄色a级片免费| 欧美另类tv| 国产精品福利一区| 日韩精品大片| 先锋av资源站| 国产99久久久精品| 成人免费在线网址| 最新中文字幕免费| 久久午夜精品| 性欧美亚洲xxxx乳在线观看| 免费在线视频观看| 欧美影视一区| 久久中文字幕一区| 日本二区三区视频| 青青草国产免费一区二区下载| 亚洲激情在线观看| 99热超碰在线| 高清欧美性猛交xxxx黑人猛| 日韩手机在线导航| 91国内在线播放| 成人av色网站| 欧美性色黄大片手机版| 三级4级全黄60分钟| 伊人久久视频| 五月婷婷综合激情| 国产日韩av网站| 激情图片在线观看高清国产| 亚洲精品网站在线观看| 久久最新免费视频| 国产三级在线播放| 亚洲蜜臀av乱码久久精品| 国产麻豆电影在线观看| 超碰免费公开在线| 亚洲一区二区三区在线看| 亚洲av综合色区| 性欧美1819sex性高清大胸| 亚洲女人****多毛耸耸8| 一级日韩一区在线观看| 成人短视频在线| 亚洲精品中文在线观看| 热久久最新网址| 美足av综合网| 粉嫩老牛aⅴ一区二区三区| 日韩少妇内射免费播放18禁裸乳| 中文字幕在线视频久| 日本福利一区二区| 欧美成人福利在线观看| 小泽玛利亚一区二区三区视频| 久久一区精品| 国产精品丝袜白浆摸在线| 中文字幕日韩三级| 国产乱码一区二区三区| 国产91精品入口17c| 婷婷丁香花五月天| 国产亚洲一本大道中文在线| 一区二区不卡在线观看| 中文在线观看免费| 岛国视频午夜一区免费在线观看| 蜜臀av午夜一区二区三区| jizz欧美| 精品免费一区二区三区| 熟女高潮一区二区三区| 欧美中文一区二区| 欧美俄罗斯性视频| 久久精品无码av| 精品亚洲porn| 国产日韩在线一区二区三区| 国产一级免费在线观看| 亚洲天堂精品视频| 大陆极品少妇内射aaaaa| 国产精品久久久久久久久免费高清 | 老司机精品福利在线观看| 国产视频二区在线观看| 亚洲精品乱码久久久久久久久| 日韩免费视频播放| 亚洲精品伦理| 亚洲精品一区中文| 欧洲猛交xxxx乱大交3| 久久精品30| 91九色在线观看| 国产午夜精品一区理论片| 一区二区三区精品视频在线| 国产免费人做人爱午夜视频| 免费一级欧美片在线观看网站| 日韩国产高清视频在线| www.xxxx日本| 日韩 欧美一区二区三区| 国产精品日韩高清| 大片免费在线看视频| 欧美日韩在线影院| 中文字幕乱码在线人视频| 禁果av一区二区三区| 欧美日本啪啪无遮挡网站| 中文字幕精品一区二| 99在线精品观看| 欧美在线观看黄| 久久青草免费| 国产亚洲精品成人av久久ww| 久久午夜无码鲁丝片| 麻豆成人久久精品二区三区红 | av免费观看久久| 91社区在线观看播放| 欧美日韩国产一区在线| 人妻互换一二三区激情视频| 红桃成人av在线播放| 97人人模人人爽人人喊中文字| 国产成人精品毛片| 亚洲欧洲日韩av| www.99r| 日韩精品首页| 国产精品一区二区三区久久久 | 亚洲国产精品欧美久久| 中文字幕在线观看一区| 韩国中文字幕av| 精品在线手机视频| 国产91精品久| 亚欧在线观看视频| 精品久久中文字幕| 日b视频在线观看| 国产日韩欧美| 欧美二区在线看| 亚洲精品88| 亚洲人成网站色ww在线| 日本特级黄色片| 久久综合九色综合欧美98| 国产免费成人在线| 一本色道久久综合亚洲精品酒店| 啪一啪鲁一鲁2019在线视频| 日本高清中文字幕二区在线| 一本到一区二区三区| 白白色免费视频| 天堂精品中文字幕在线| 日韩欧美在线观看强乱免费| 欧美va视频| 色系列之999| 国产美女三级无套内谢| 亚洲综合激情小说| 999精品免费视频| 国产欧美一级| 亚洲精品一区二区三| 欧美韩国日本| 久久99精品久久久久久琪琪| 国模私拍视频在线| 精品人伦一区二区三区蜜桃网站| 99久久久久久久久久| 日韩影院在线观看| 自拍偷拍一区二区三区| 日本精品在线观看| 91av视频在线观看| av网在线观看| 日韩欧美国产wwwww| 亚洲精品国产精品乱码| 国产色综合一区| 亚洲高清在线不卡| 亚洲精品九九| 四虎影院一区二区三区 | 男人c女人视频| 欧美网色网址| 国产精品偷伦视频免费观看国产| 69xxx在线| 亚洲精品一区中文| 国产又粗又猛又爽又黄视频 | 亚洲国产精品免费视频| 97久久久久久| 免费a在线看| 日韩av一区在线| 中文字幕久久网| 亚洲www啪成人一区二区麻豆| 免费毛片视频网站| 国产精品亚洲午夜一区二区三区| 欧美 日韩 国产一区| 亚洲五月综合| 日本在线观看一区二区三区| 久久影院一区二区三区| 欧美综合第一页| 丝袜综合欧美| 在线日韩欧美视频| 黄色av免费观看| 欧美日本在线播放| 成人毛片在线播放| 亚洲国产视频一区| 网爆门在线观看| 91蜜桃免费观看视频| 亚洲网中文字幕| 丝袜亚洲另类丝袜在线| 国产精品久久久久7777| 999国产精品永久免费视频app| 国产综合 伊人色| 久久久久亚洲精品中文字幕| 国产成人一区二| 国产自产自拍视频在线观看| 精品中文字幕乱| 在线激情免费视频| 亚洲欧美变态国产另类| 亚洲精品视频91| 91精品国产色综合久久| 亚洲第一网站在线观看| 亚洲国产日韩精品| 欧美日韩亚洲国产另类| 国产精品人妖ts系列视频| 亚洲第一黄色网址| 成人免费视频视频在线观看免费| 伊人色在线视频| 蜜臀av在线播放一区二区三区| 国产精品69久久久| 中文字幕一区二区三区在线视频| 亚洲一区尤物| 久久国产电影| 亚洲欧洲日韩综合二区| 波多野结衣一区| 热舞福利精品大尺度视频| 秋霞在线一区| 精品一区二区三区自拍图片区| 视频一区视频二区欧美| 51国偷自产一区二区三区的来源| 亚洲香蕉久久| 成人写真视频福利网| 亚洲免费一区| 成人精品久久久| 99久久这里有精品| 亚洲va电影大全| 国产精品亚洲四区在线观看| 国产在线日韩在线| 亚洲视频资源| 91精品综合久久| 精品国产欧美| 国产精品伊人日日| 欧美1区2区3区4区| 欧美日韩中文国产一区发布| 国产成人3p视频免费观看| 日韩wuma| 999久久久精品国产| 日本黄色播放器| 欧美黄色大片网站| 国产色一区二区三区| 国产亚洲毛片| 黄色片视频在线播放| 日本成人超碰在线观看| 2025韩国理伦片在线观看| 久久99精品国产.久久久久久| 涩多多在线观看| 成人一区二区三区在线观看| 国产精品福利导航| 国产欧美一区二区三区在线看蜜臀| 99久久久无码国产精品不卡| 成人欧美一区二区三区视频网页| 国产97免费视频| 亚洲成人自拍网| 日本免费在线观看视频| 色视频欧美一区二区三区| 一级黄色大片免费| 日韩免费视频一区| 全部免费毛片在线播放网站| 最近2019年手机中文字幕| 四虎影院观看视频在线观看| 欧美一区二三区| 日韩有码欧美| 国产精品一区二区av| 国产欧美日韩一区二区三区四区| 亚洲一区二区三区精品在线观看 | 国产真实有声精品录音| 男人天堂成人网| 国产精品日韩欧美一区| 91 在线视频观看| 成人18精品视频| 少妇精品无码一区二区免费视频| 亚洲男女一区二区三区| 99热只有这里有精品| 欧美日韩大陆在线| 少妇精品高潮欲妇又嫩中文字幕 | 变态调教一区二区三区| 国产精品视频播放| 国产精品一区二区三区美女| 亚洲精品成人三区| 亚洲激精日韩激精欧美精品| 美女少妇一区二区| 99久久婷婷国产综合精品电影| 国产人与禽zoz0性伦| 精品福利樱桃av导航| 国产精品伊人久久| 亚洲视频欧美视频| h片在线观看视频免费| 成人看片人aa| 国产探花在线精品一区二区| www.国产在线播放| 韩日av一区二区| 欧美另类z0zx974| 婷婷中文字幕一区三区| 99精品久久久久久中文字幕| 国产一区二区三区在线观看视频 | 欧美xxxx黑人又粗又长密月| 欧美国产先锋| 捷克做爰xxxⅹ性视频| 国产日韩欧美激情| 久久久国产精品成人免费| 日韩午夜在线观看视频| 日本在线免费播放| 国产不卡在线观看| 色综合www| 青青草视频在线免费播放| 国产一区二区福利视频| 国产午夜精品福利视频| 一本一本大道香蕉久在线精品| 精品国产九九九| 久久久精品久久久久| 国产91亚洲精品久久久| 偷拍视频一区二区| 老牛嫩草一区二区三区日本 | 蜜桃久久一区二区三区| 欧美成人精品一区二区| 99tv成人影院| 色呦呦网站入口| 久草中文综合在线| av在线免费播放网址| 欧美三级视频在线观看| av资源网在线观看| 国产精品偷伦视频免费观看国产 | 97精品久久久中文字幕免费| 日本免费一区二区三区视频| 中国黄色录像片| 国产剧情av麻豆香蕉精品| 福利所第一导航| 日韩美女视频一区二区在线观看| 在线不卡日本v二区707| 97视频热人人精品| 国自产拍偷拍福利精品免费一| 男男受被啪到高潮自述| 亚洲综合成人在线| 欧美一级免费片| 欧美诱惑福利视频| 国产精品美女久久久久久不卡| 中文字幕永久视频| 国产精品丝袜91| 国产喷水吹潮视频www| 欧美精品制服第一页| 懂色av一区二区| 久久网站免费视频| 欧美韩国日本不卡| 国产夫绿帽单男3p精品视频| 欧美极品少妇全裸体| 香蕉久久99| 亚洲一区二区三区观看| 亚洲综合免费观看高清完整版在线 | 性欧美freesex顶级少妇| 日本高清不卡一区二区三| 免费成人美女在线观看.| 精品亚洲乱码一区二区| 日韩欧美在线观看一区二区三区| 国产在线xxx| 日韩精品无码一区二区三区| 久久91精品久久久久久秒播| 久久久久黄色片| 亚洲欧美在线一区二区| 9999精品| 欧美性大战久久久久xxx| 国产精品乱码人人做人人爱| 国产视频第一页| 91福利视频在线观看| 日韩啪啪电影网| 一级黄色片毛片| 欧美日韩一区二区三区在线| 日本在线视频网址| 日韩福利视频| 国产福利91精品一区二区三区| chinese国产精品| 久久成人一区二区| 少妇精品久久久一区二区| 久久久福利影院| 一本大道久久a久久精品综合| 黄视频网站在线| 欧美极品日韩| 国产精品1区二区.| 波多野结衣影片| 久久久欧美精品| 99久久精品网| 给我看免费高清在线观看| 日韩欧美中文字幕一区| 日韩在线短视频| 国产97在线 | 亚洲| 亚洲人成在线播放网站岛国| 狠狠v欧美ⅴ日韩v亚洲v大胸 |