代碼隨想錄算法訓練營第36期DAY51

DAY51

121買賣股票的最佳時機

做過了。算是二刷:來自力扣優質題解

貪心:

每次記錄更新最小點和最大出售值。

  1. class?Solution?{
  2. public:
  3. ????int?maxProfit(vector<int>&?prices)?{
  4. ????????int?cur,res=INT_MIN,curmin=INT_MAX;
  5. ????????for(int?i=0;i<prices.size();i++){
  6. ????????????if(prices[i]<curmin)?curmin=prices[i];
  7. ????????????cur=prices[i]-curmin;
  8. ????????????if(cur>res)?res=cur;
  9. ????????}
  10. ????????return?res;
  11. ????}
  12. };

暴力:

  1. class?Solution?{
  2. public:
  3. ????int?maxProfit(vector<int>&?prices)?{
  4. ????????int?res=0;
  5. ????????for(int?i=0;i<prices.size();i++){
  6. ????????????for(int?j=i+1;j<prices.size();j++)
  7. ????????????res=max(res,prices[j]-prices[i]);
  8. ????????}
  9. ????????return?res;
  10. ????}
  11. };

動態規劃:

算是比較系統的東西,記在紙質筆記本吧。

  1. class?Solution?{
  2. public:
  3. ????int?maxProfit(vector<int>&?prices)?{
  4. ????????if(prices.size()==1)?return?0;
  5. ????????vector<vector<int>>?dp(prices.size(),vector<int>(2));
  6. ????????dp[0][0]=-1*prices[0];
  7. ????????dp[0][1]=0;
  8. ????????for(int?i=1;i<prices.size();i++){
  9. ????????????dp[i][0]=max(-prices[i],dp[i-1][0]);
  10. ????????????dp[i][1]=max(prices[i]+dp[i-1][0],dp[i-1][1]);
  11. ????????}
  12. ????????return?dp[prices.size()-1][1];
  13. ????}
  14. };

滾動數組法:

  1. class?Solution?{
  2. public:
  3. ????int?maxProfit(vector<int>&?prices)?{
  4. ????????if(prices.size()==1)?return?0;
  5. ????????vector<int>?dp(2);
  6. ????????dp[0]=-1*prices[0];
  7. ????????dp[1]=0;
  8. ????????for(int?i=1;i<prices.size();i++){
  9. ????????????dp[0]=max(-prices[i],dp[0]);
  10. ????????????dp[1]=max(prices[i]+dp[0],dp[1]);
  11. ????????}
  12. ????????return?dp[1];
  13. ????}
  14. };

時間竟然也快了很多,不知道為什么。

122買賣股票的最佳時機ii

做過貪心法:只要能賺錢就買賣。

  1. class?Solution?{
  2. public:
  3. ????int?maxProfit(vector<int>&?prices)?{
  4. ????????if(prices.size()==1)?return?0;
  5. ????????int?sum=0;
  6. ????????for(int?i=1;i<prices.size();i++){
  7. ????????????int?res=prices[i]-prices[i-1];
  8. ????????????if(res>0)?sum+=res;
  9. ????????}
  10. ????????return?sum;
  11. ????}
  12. };

動態規劃:

想對了,[多次買入和一次買入]和上一題不同的地方就是多了一個項:-price[i]不夠了,要寫成:dp[i-1][1]-price[i]

  1. class?Solution?{
  2. public:
  3. ????int?maxProfit(vector<int>&?prices)?{
  4. ????????if?(prices.size()?==?1)
  5. ????????????return?0;
  6. ????????vector<vector<int>>?dp(prices.size(),?vector<int>(2));
  7. ????????dp[0][0]?=?-1?*?prices[0];
  8. ????????dp[0][1]?=?0;
  9. ????????for?(int?i?=?1;?i?<?prices.size();?i++)?{
  10. ????????????dp[i][0]?=?max(dp[i?-?1][1]?-?prices[i],?dp[i?-?1][0]);
  11. ????????????dp[i][1]?=?max(dp[i?-?1][0]?+?prices[i],?dp[i?-?1][1]);
  12. ????????}
  13. ????????return?dp[prices.size()?-?1][1];
  14. ????}
  15. };

滾動數組:

  1. class?Solution?{
  2. public:
  3. ????int?maxProfit(vector<int>&?prices)?{
  4. ????????if?(prices.size()?==?1)
  5. ????????????return?0;
  6. ????????vector<int>?dp(2);
  7. ????????dp[0]?=?-1?*?prices[0];
  8. ????????dp[1]?=?0;
  9. ????????for?(int?i?=?1;?i?<?prices.size();?i++)?{
  10. ????????????dp[0]?=?max(dp[1]?-?prices[i],?dp[0]);
  11. ????????????dp[1]?=?max(dp[0]?+?prices[i],?dp[1]);
  12. ????????}
  13. ????????return?dp[1];
  14. ????}
  15. };

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

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

相關文章

從軍事角度理解“戰略與戰術”

戰略與戰術&#xff0c;均源于軍事術語。 戰略&#xff08;Strategy&#xff09;&#xff0c;源自希臘語詞匯“strategos&#xff08;將軍&#xff09;”和“strategia&#xff08;軍事指揮部&#xff0c;即將軍的辦公室和技能&#xff09;”。指的是指揮全局性作戰規劃的謀略…

【位運算】【前綴和】個人練習-Leetcode-1177. Can Make Palindrome from Substring

題目鏈接&#xff1a;https://leetcode.cn/problems/can-make-palindrome-from-substring/description/ 題目大意&#xff1a;給出一個字符串s&#xff0c;每次query給出l, r, k&#xff0c;要求判斷子串s[l:r1]在經過k次操作后是否能變為回文串。一次操作可以將子串內的一個字…

mysql 數據庫在liunx 上的備份和恢復

一. mysql 數據庫備份 sh 腳本 1. vim sqlback.sh #!/bin/bashUSER"root" #賬號 PASSWORD"123456" #密碼 DATABASE"test" #數據庫名 BACKUP_DIR"/home/dev/mysql" #備份存的目錄 TIMESTAMP$(date "%F") …

搭建python虛擬環境,并在VSCode中使用

創建環境 python -m venv E:\python\flask\venv激活環境 運行下圖所示的bat文件 退出環境 執行下面的語句 deactivateVSCode中配置&#xff1a; ①使用CTRLshiftp命令&#xff0c;使用CTRLshiftp命令&#xff0c;輸入&#xff1a; Python: Select Interpreter②選擇之前創建…

【計算視覺】學習計算機視覺你不得不膜拜的CVPR大神:何凱明

目錄 第一章&#xff1a;CVPR——計算機視覺的終極擂臺 第二章&#xff1a;何凱明——計算機視覺領域的耀眼星辰 第三章&#xff1a;高引用論文——計算機視覺研究的璀璨星辰 第四章&#xff1a;何凱明的CVPR論文——深度學習的探索之旅 第五章&#xff1a;結語——向何凱…

翻譯《The Old New Thing》- Why isn’t there a SendThreadMessage function?

Why isnt there a SendThreadMessage function? - The Old New Thing (microsoft.com)https://devblogs.microsoft.com/oldnewthing/20081223-00/?p19743 Raymond Chen 2008年12月23日 為什么沒有 SendThreadMessage 函數&#xff1f; 簡要 文章討論了 Windows 中不存在 Sen…

WHAT - 發布訂閱

目錄 一、常見實現方案1.1 使用事件發射器&#xff08;Event Emitter&#xff09;1.2 自定義事件系統&#xff08;EventBus&#xff09;1.3 使用庫如 PubSubJS1.4 使用框架內置的狀態管理工具Vue.jsReact (使用 Context API 或 Redux) 二、先后關系2.1 緩存事件數據2.2 使用 Re…

React hooks動態配置側邊欄

React hooks根據不同需求 還有不同的角色 動態的去配置側邊欄 需求&#xff1a; 點擊某個按鈕是一套側邊欄 &#xff0c;不同角色&#xff08;比如管理員之類的權限高一點&#xff09;比普通用戶多個側邊欄 然后點擊另一個按鈕是另一套側邊欄 此時&#xff0c;就需要動態的去…

【React】classnames 優化類名控制

1. 介紹 classnames是一個簡單的JS庫&#xff0c;可以非常方便的通過條件動態的控制class類名的顯示 ClassNames是一個用于有條件處理classname字符串連接的庫 簡單來說就是動態地去操作類名&#xff0c;把符合條件的類名粘在一起 現在的問題&#xff1a;字符串的拼接方式不…

KMeans聚類分析星

1. datasample initial_centroids datasample(data, k, Replace, false); 是MATLAB中的命令&#xff0c;用于從數據集data中隨機抽取k個樣本作為初始聚類匯總新&#xff0c;并且抽取時不放回。 datasample&#xff1a;是MATLAB中的函數&#xff0c;用于從數組中隨機抽取樣本d…

halcon算子之prepare_object_model_3d詳解

為某一操作準備三維對象模型。 Description 操作符prepare_object_model_3d準備3D對象模型ObjectModel3D,用于下面目的中給出的操作。它計算操作所需的值并將其存儲在ObjectModel3D中,從而加快了后續操作。沒有必要調用prepare_object_model_3d。但是,如果要多次使用3D對象…

5、js關于數組的常用方法(19種)

一、改變原數組的方法 1.push&#xff08;&#xff09; 末尾添加數據 語法&#xff1a; arr.push(要插入的數據可以多個) // push 尾部添加數據const arr [1,2,3,4,5];arr.push(6,7);console.log(arr);//(7) [1, 2, 3, 4, 5, 6, 7]2. pop&#xff08;&#xff09; 末尾刪除一…

大疆智圖_空三二維重建成果傳輸

一、軟件環境 1.1 所需軟件 1、 大疆智圖&#xff1a;點擊下載&#xff1b; ??2、 ArcGIS Pro 3.1.5&#xff1a;點擊下載&#xff0c;建議使用IDM或Aria2等多線程下載器&#xff1b; ??3、 IDM下載器&#xff1a;點擊下載&#xff0c;或自行搜索&#xff1b; ??4、 Fas…

探索 Noisee AI 的奇妙世界與變現之旅

日賺800&#xff0c;利用淘寶/閑魚進行AI音樂售賣實操 如何讓AI生成自己喜歡的歌曲-AI音樂創作的正確方式 抖音主播/電商人員有福了&#xff0c;利用Suno創作產品宣傳&#xff0c;讓產品動起來-小米Su7 用sunoAI寫粵語歌的方法&#xff0c;博主已經親自實踐可行 五音不全也…

[經驗] 潿洲島在廣西嗎 #職場發展#知識分享#媒體

潿洲島在廣西嗎 廣西潿洲島&#xff0c;是中國南海上的一顆閃亮明珠&#xff0c;位于廣西北部灣沿海&#xff0c;東經108.71度&#xff0c;北緯21.54度&#xff0c;距離北海市區30公里&#xff0c;是中國最大的海島之一&#xff0c;風景秀麗&#xff0c;氣候溫和。島上山青水秀…

!力扣3. 無重復字符的最長子串

給定一個字符串 s &#xff0c;請你找出其中不含有重復字符的 最長子串的長度。 示例 1: 輸入: s "abcabcbb" 輸出: 3 解釋: 因為無重復字符的最長子串是"abc"&#xff0c;所以其長度為 3 示例 2: 輸入: s "bbbbb" 輸出: 1 …

PCE自動裝機

服務端和客戶端 pxe&#xff1a;c/s模式&#xff0c;允許客戶端通過遠程服務器(服務端)下載引導鏡像&#xff0c;加載安裝吻技安&#xff0c;實現自動化安裝操作系統。 無人值守&#xff1a;安裝選項不需要認為干預&#xff0c;可以自動化實現。 pxe優點&#xff1a; 1.規模…

Overall timing accuracy 和Edge placement accuracy 理解

在電子設計自動化(EDA)、集成電路(IC)制造和高速數字電路設計領域,"Overall Timing Accuracy" 和 "Edge Placement Accuracy" 是兩個關鍵的性能指標,它們對于確保電路的功能正確性和性能至關重要。 當涉及到“Overall timing accuracy”(總體時序精度)…

最小相位系統

最小相位系統 1、傳遞函數 一個線性系統的響應。 比如一個RC低通濾波器&#xff1a; 交流分量在電容的充放電中被濾除掉&#xff0c;通過設置電容器的電容值&#xff0c;以及電阻值&#xff0c;能夠控制這種濾除能力&#xff0c;這個參數為RC。 電容的電抗為 1 / j w C 1/j…

單片機+TN901非接觸式紅外測溫設計

摘要 溫度測量技術應用十分廣泛&#xff0c;而且在現代設備故障檢測領域中也是一項非常重要的技術。但在某些應用領域中&#xff0c;要求測量溫度用的傳感器不能與被測物體相接觸&#xff0c;這就需要一種非接觸的測溫方式來滿足上述測溫需求。本論文正是應上述實際需求而設計的…