【算法】貪心算法:擺動序列C++

文章目錄

  • 前言
  • 題目解析
  • 算法原理
  • 代碼示例
  • 策略證明

前言

題目的鏈接,大家可以先試著去做一下再來看一下思路。376. 擺動序列 - 力扣(LeetCode)

題目解析

將題目有用的信息劃出來,結合示例認真閱讀,去理解題目。

在這里插入圖片描述

我們的擺動序列可能不是唯一的,但是我們只需要返回最長子序列的長的就ok了,像題目里面給的示例2就有這種情況,紫色劃線組成的數組的最長子序列是7,但是藍色劃線的數組成的最長子序列的長度也是7。
所以我們一定要認真看題目給的示例,然后去挖掘一下題目給的示例沒有的情況。

在這里插入圖片描述

算法原理

在這里插入圖片描述

代碼示例

class Solution {
public:int wiggleMaxLength(vector<int>& nums) {int n=nums.size();if(n<2) return n;//首先去處理特殊情況,就是數組中數只有一個的情況int ret = 0, left= 0;//ret用表示最長子序列的長度,left表示某點左側鄰域是遞增還是遞減。for(int i=0; i<n-1; i++)//我們這里不用判斷最后一個數,因為最后一個點我們是一定要選的,所以返回時ret要加一。{int right=nums[i+1]-nums[i];//算出該點右側鄰域是遞增還是遞減。if(right==0) continue;//這里時判斷右側點的值是否與當前點的值相等。if(right*left<=0) ret++;left=right;//將right的值賦給left,當i到當前點的下一個點的時候,此時的left則是下一個點左側鄰域的遞增減情況。}return ret+1;}
};

策略證明

證明方法:反證法
在這里插入圖片描述

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

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

相關文章

【DOCKER】-6 docker的資源限制與監控

文章目錄1、docker的資源限制1.1 容器資源限制的介紹1.2 OOM1.3 容器的內存限制1.3.1 內存限制的相關選項1.4 容器的CPU限制介紹2、docker的監控插件2.1 cadvisor2.2 portainer1、docker的資源限制 1.1 容器資源限制的介紹 默認情況下&#xff0c;容器沒有資源的使用限制&…

gcc 源碼分析--gimple 關鍵數據結構

gimple 操作碼&#xff0c;支持這些&#xff1a;DEFGSCODE(GIMPLE_symbol, printable name, GSS_symbol). */ DEFGSCODE(GIMPLE_ERROR_MARK, "gimple_error_mark", GSS_BASE) DEFGSCODE(GIMPLE_COND, "gimple_cond", GSS_WITH_OPS) DEFGSCODE(GIMPLE_DEBU…

TDengine GREATEST 和 LEAST 函數用戶手冊

TDengine GREATEST 和 LEAST 函數用戶手冊 1. 需求背景 1.1 問題描述 在實際生產過程中&#xff0c;客戶經常需要計算三相電流、電壓的最大值和最小值。傳統的實現方式需要使用復雜的 CASE WHEN 語句&#xff0c;例如&#xff1a; -- 傳統方式&#xff1a;計算三相電流最大…

Redis 與數據庫不一致問題及解決方案

一、不一致的原因分析 1. 緩存更新策略不當 先更新數據庫后刪除緩存:刪除緩存失敗會導致不一致 先刪除緩存后更新數據庫:并發請求可能導致不一致 緩存穿透:大量請求直接打到數據庫,繞過緩存 2. 并發操作問題 讀寫并發:讀請求獲取舊緩存時,寫請求更新了數據庫但未更新緩存…

iOS 加固工具使用經驗與 App 安全交付流程的實戰分享

在實際開發中&#xff0c;iOS App不僅要安全&#xff0c;還要能被穩定、快速、無誤地交付。這在外包、B端項目、渠道分發、企業自用系統等場景中尤為常見。 然而&#xff0c;許多開發者在引入加固工具后會遇到以下困擾&#xff1a; 混淆后App運行異常、不穩定&#xff1b;資源路…

Windows 下 Visual Studio 開發 C++ 項目的部署流程

在Windows環境中使用Visual Studio&#xff08;以下簡稱VS&#xff09;開發C項目時&#xff0c;“部署”是確保程序能在目標設備上正常運行的關鍵環節。部署的核心目標是&#xff1a;將編譯生成的可執行文件&#xff08;.exe&#xff09;、依賴的動態鏈接庫&#xff08;.dll&am…

yolo8+聲紋識別(實時字幕)

現在已經完成了人臉識別跟蹤 ?&#xff0c;接下來要&#xff1a; ? 加入「聲紋識別&#xff08;說話人識別&#xff09;」功能&#xff0c;識別誰在講話&#xff0c;并在視頻中“這個人”的名字旁邊加上「正在講話」。 這屬于多模態識別&#xff08;視覺 音頻&#xff09;&a…

DH(Denavit–Hartenberg)矩陣

DH 矩陣&#xff08;Denavit-Hartenberg 矩陣&#xff09;是 1955 年由 Denavit 和 Hartenberg 提出的一種機器人運動學建模方法&#xff0c;用于描述機器人連桿和關節之間的關系。該方法通過在機器人每個連桿上建立坐標系&#xff0c;并用 44 的齊次變換矩陣&#xff08;DH 矩…

Vim的magic模式

在 Vim 中&#xff0c;magic 模式用于控制正則表達式中特殊字符的解析方式。它決定了哪些字符需要轉義才能發揮特殊作用&#xff0c;從而影響搜索和替換命令的寫法。以下是詳細介紹&#xff1a; 一、三種 magic 模式 Vim 提供三種 magic 模式&#xff0c;通過在正則表達式前添加…

Git 使用技巧與原理(一)—— 基礎操作

1、起步 1.1 版本控制 版本控制是一種記錄一個或若干文件內容變化&#xff0c;以便將來查閱特定版本修訂情況的系統。 版本控制系統&#xff08;VCS&#xff0c;Version Control System&#xff09;通常可以分為三類&#xff1a; 本地版本控制系統&#xff1a;大多都是采用某…

軟件測試之自動化測試

目錄 1.什么是自動化測試 2.web?動化測試 2.1驅動 WebDriverManager 3. Selenium 3.1selenium驅動瀏覽器的?作原理 4.常用函數 4.1元素的定位 4.1.1cssSelector選擇器 4.2.2xpath 4.2操作測試對象 4.3窗? 4.4等待 4.5瀏覽器導航 4.6彈窗 4.7文件上傳 4.8設置…

sqlserver遷移日志文件和數據文件

sqlserver安裝后沒有指定日志存儲路徑或者還原庫指定的日志存儲位置不理想想要更改&#xff0c;都可以按照這種方式來更換&#xff1b;1.前提準備&#xff1a;數據庫的備份bak文件2.查看自己當前數據庫的日志文件和數據文件存儲路徑是否理想選中當前數據庫&#xff0c;右鍵屬性…

MFC UI表格制作從專家到入門

文章目錄CListCtrl常見問題增強版CGridCtrl&#xff08;第三方&#xff09;第三方庫ReoGridCListCtrl 默認情況下&#xff0c;CListCtrl不支持直接編輯單元格&#xff0c;需通過消息處理實現。 1.添加控件到資源視圖 在對話框資源編輯器中拖入List Control控件&#xff0c;設…

數字后端APR innovus sroute到底是如何選取寬度來鋪power rail的?

吾愛IC社區新一期IC訓練營將于7月初開班&#xff08;07.06號晚上第一次直播課&#xff09;&#xff01;社區所有IC后端訓練營課程均為直播課&#xff01;全網唯一一家敢開后端直播課的&#xff08;口碑不好招生一定存在困難&#xff0c;自然就無法開直播課&#xff09;&#xf…

LVS集群技術

LVS&#xff08;Linux Virtual Server&#xff09;是一種基于Linux內核的高性能、高可用性服務器集群技術&#xff0c;它通過負載均衡將客戶端請求分發到多臺后端真實服務器&#xff0c;實現 scalability 和 fault tolerance。LVS工作在傳輸層&#xff08;OSI Layer 4&#xff…

git項目,有idea文件夾,怎么去掉

要從Git項目中排除.idea文件夾&#xff08;IntelliJ IDEA的配置文件目錄&#xff09;&#xff0c;可以通過以下步驟操作&#xff1a; 1. 添加.gitignore規則 在項目根目錄創建或編輯.gitignore文件&#xff0c;添加以下內容&#xff1a; .idea/2. 從Git緩存中刪除已跟蹤的.idea…

springboot+swagger2文檔從swagger-bootstrap-ui更換為knife4j及文檔接口參數不顯示問題

背景 已有springboot項目,且使用的是swagger2+swagger-bootstrap-ui的版本 1.pom依賴如下 <!-- Swagger接口管理工具 --><dependency><groupId>io.springfox</groupId><artifactId>springfox-swagger2</artifactId><version>2.9…

mysql數據庫表只能查詢,對于插入、更新、刪除操作一直卡住,直到報錯Lost connection to MySQL server during query

診斷步驟1. 查看阻塞進程SELECT * FROM performance_schema.metadata_locks WHERE LOCK_STATUS PENDING;SELECT * FROM sys.schema_table_lock_waits;2. 查看當前活動事務SELECT * FROM information_schema.INNODB_TRX;3. 查看進程列表SHOW PROCESSLIST;通過SELECT * FROM in…

Redis BigKey 深度解析:從原理到實戰解決方案

引言&#xff1a;什么是 BigKey&#xff1f;在 Redis 的使用場景中&#xff0c;BigKey&#xff08;大鍵&#xff09;是指那些數據量異常龐大的鍵值&#xff0c;通常表現為&#xff1a;String 類型&#xff1a;值大小超過 10KBHash/Set 等&#xff1a;元素數量超過 5000List/ZSe…

Qt 實現新手引導

Qt實現新手引導 對于一個新安裝的軟件或者一個新的功能&#xff0c;提供一個新手引導步驟&#xff0c;能夠讓用戶快速熟悉。這是最終效果&#xff0c;每一個按鈕都會有一個簡單引導&#xff0c;通過點擊上一步、下一步來切換不同的指導。當前引導的功能&#xff0c;會有一個高光…