[Algorithm][動態規劃][簡單多狀態DP問題][按摩師][打家劫舍Ⅱ][刪除并獲得點數][粉刷房子]詳細講解

目錄

  • 1.按摩師
    • 1.題目鏈接
    • 2.算法思路詳解
    • 3.代碼實現
  • 2.打家劫舍 II
    • 1.題目鏈接
    • 2.算法思路詳解
    • 3.代碼實現
  • 3.刪除并獲得點數
    • 1.題目鏈接
    • 2.算法思路詳解
    • 3.代碼實現
  • 4.粉刷房子
    • 1.題目鏈接
    • 2.算法思路詳解
    • 3.代碼實現


1.按摩師

1.題目鏈接

  • 按摩師

2.算法思路詳解

  • 思路
    • 確定狀態表示 -> dp[i]的含義

      • 選擇到i位置的時候,此時的最長預約時長
      • 本題,狀態表示還可以繼續細分:
        • f[i]:選擇到i位置的時候,nums[i]必選,此時的最長預約時長
        • g[i]:選擇到i位置的時候,nums[i]不選,此時的最長預約時長
    • 推導狀態轉移方程

      • f[i] = g[i - 1] + nums[i]
      • g[i] = max(f[i - 1], g[i - 1])
        請添加圖片描述
    • 初始化:f[0] = nums[0], g[0] = 0

    • 確定填表順序:從左往右,兩個表一起填

    • 確定返回值:max(f[n - 1], g[n - 1])


3.代碼實現

int massage(vector<int>& nums) 
{int n = nums.size();if(n == 0) return 0;vector<int> f(n);vector<int> g(n);f[0] = nums[0];for(int i = 1; i < n; i++){f[i] = g[i - 1] + nums[i];g[i] = max(f[i - 1], g[i - 1]);}return max(f[n - 1], g[n - 1]);
}

2.打家劫舍 II

1.題目鏈接

  • 打家劫舍 II

2.算法思路詳解

  • 思路解析:本題比打家劫舍Ⅰ只多了環形問題,那么只需將環形問題分類討論(依據nums[0]),拆解為兩個線性的打家劫舍Ⅰ問題即可
    • 第一個位置偷nums[0] + _rob[2, n - 2] <— 第二個位置和最后一個位置不偷
    • 第一個位置不偷_rob(1, n - 1) <— 偷第二個位置和最后一個位置
  • 思路
    • 確定狀態表示 -> dp[i]的含義

      • i位置的時候,此時的最大金額
      • 本題,狀態表示還可以繼續細分:
        • f[i]:偷到i位置的時候,nums[i]必偷,此時的最大金額
        • g[i]:偷到i位置的時候,nums[i]不偷,此時的最大金額
    • 推導狀態轉移方程

      • f[i] = g[i - 1] + nums[i]
      • g[i] = max(f[i - 1], g[i - 1])
        請添加圖片描述
    • 初始化:f[0] = nums[0], g[0] = 0

    • 確定填表順序:從左往右,兩個表一起填

    • 確定返回值:max(f[n - 1], g[n - 1])


3.代碼實現

class Solution
{
public:int rob(vector<int>& nums) {int n = nums.size();// 分類討論,取兩種情況中的最大值return max(nums[0] + _rob(nums, 2, n - 2), _rob(nums, 1, n - 1));}int _rob(vector<int>& nums, int left, int right){if(left > right) return 0;int n = nums.size();vector<int> f(n); // 選vector<int> g(n); // 不選f[left] = nums[left];for(int i = left + 1; i <= right; i++){f[i] = g[i - 1] + nums[i];g[i] = max(f[i - 1], g[i - 1]);}return max(f[right], g[right]);}
};

3.刪除并獲得點數

1.題目鏈接

  • 刪除并獲得點數

2.算法思路詳解

  • 思路解析:本題可以先做一個預處理,將問題轉化為打家劫舍

    • 思路
      • 打家劫舍要求訪問數組中的數的順序是連續的,但本題原始數組顯然不符合要求
      • 雖然原始數組數值不符合要求,但是經過轉換,數組下標是可以符合順序連續的
    • 做法
      • 將原始數組中的數,統計到arr,然后在arr中,做一次打家劫舍問題即可
      • 此時,數值相同的值的和可以被其本身值作為arr的下標索引到 <— hash[x] = sum(x)
      • arr[i]i這個數出現的總和
        請添加圖片描述
  • 思路

    • 確定狀態表示 -> dp[i]的含義

      • i位置的時候,此時獲得的最大點數
      • 本題,狀態表示還可以繼續細分:
        • f[i]:選到i位置的時候,nums[i]必選,此時獲得的最大點數
        • g[i]:選到i位置的時候,nums[i]不選,此時獲得的最大點數
    • 推導狀態轉移方程

      • f[i] = g[i - 1] + arr[i]
      • g[i] = max(f[i - 1], g[i - 1])
        請添加圖片描述
    • 初始化:f[0] = arr[0], g[0] = 0

    • 確定填表順序:從左往右,兩個表一起填

    • 確定返回值:max(f[n], g[n])


3.代碼實現

int deleteAndEarn(vector<int>& nums) 
{sort(nums.begin(), nums.end());int n = nums.back(); // maxvector<int> arr(n + 1);for(auto& x : nums){arr[x] += x;}vector<int> f(n + 1);vector<int> g(n + 1);for(int i = 1; i <= n; i++){f[i] = g[i - 1] + arr[i];g[i] = max(f[i - 1], g[i - 1]);}return max(f[n], g[n]);
}

4.粉刷房子

1.題目鏈接

  • 粉刷房子

2.算法思路詳解

  • 思路
    • 確定狀態表示 -> dp[i][j]的含義:i -> 到了哪個位置,j -> 這個位置的哪個顏色

      • dp[i][0]:粉刷i位置的時候,最后一個位置刷上紅色,此時的最小花費
      • dp[i][1]:粉刷i位置的時候,最后一個位置刷上藍色,此時的最小花費
      • dp[i][2]:粉刷i位置的時候,最后一個位置刷上綠色,此時的最小花費
        請添加圖片描述
    • 推導狀態轉移方程

      • dp[i][0] = min(dp[i - 1][1], dp[i - 1][2]) + costs[i - 1][0]
      • dp[i][1] = min(dp[i - 1][0], dp[i - 1][2]) + costs[i - 1][1]
      • dp[i][2] = min(dp[i - 1][0], dp[i - 1][1]) + costs[i - 1][2]
        請添加圖片描述
    • 初始化:dp[0][0] = dp[0][1] = dp[0][2] = 0

    • 確定填表順序:從左往右,一次填寫三個表

    • 確定返回值:min(dp[n][0], min(dp[n][1], dp[n][2]))


3.代碼實現

int minCost(vector<vector<int>>& costs) 
{int n = costs.size();vector<vector<int>> dp(n + 1, vector<int>(3));for(int i = 1; i <= n; i++){dp[i][0] = min(dp[i - 1][1], dp[i - 1][2]) + costs[i - 1][0];dp[i][1] = min(dp[i - 1][0], dp[i - 1][2]) + costs[i - 1][1];dp[i][2] = min(dp[i - 1][0], dp[i - 1][1]) + costs[i - 1][2];}return min(dp[n][0], min(dp[n][1], dp[n][2]));
}

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

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

相關文章

大模型提示詞Prompt學習

引言 關于chatGPT的Prompt Engineer&#xff0c;大家肯定耳朵都聽起繭了。但是它的來由&#xff1f;&#xff0c;怎么能用好&#xff1f;很多人可能并不覺得并不是一個問題&#xff0c;或者說認定是一個很快會過時的概念。但其實也不能說得非常清楚&#xff08;因為覺得沒必要深…

Redis第18講——Redis和Redission實現延遲消息

即使不是做電商業務的同學&#xff0c;也一定知道訂單超時關閉這種業務場景&#xff0c;這個場景大致就是用戶下單后&#xff0c;如果在一定時間內未支付&#xff08;比如15分鐘、半小時&#xff09;&#xff0c;那么系統就會把這筆訂單給關閉掉。這個功能實現的方式有很多種&a…

unity開發Hololens 制作滑動框

一定要做到最后一步&#xff0c;才會有效果 1、創建空物體 ,并添加組件 創建空物體 命名ScrollingObjectCollection&#xff0c; 添加組件如下圖 下面是各個組件展開的內容 2、在ScrollingObjectCollection 下面創建兩個空物體&#xff0c;分別命名Container、Clipping…

運籌說 第115期 | 排隊論經典例題講解

通過前幾期的學習&#xff0c;我們已經學會了排隊論的基本概念、生滅過程和Poisson過程&#xff0c;等待制排隊模型、混合制排隊模型、其他排隊模型以及排隊系統優的定義與相關求解方法。在實際工作中&#xff0c;我們能發現排隊論在經濟管理中有著許多應用&#xff0c;本期小編…

大數據量上傳FTP

背景 筆者有一個需求是把將近一億條數據上傳到FTP服務器中&#xff0c;這些數據目前是存儲在mysql中&#xff0c;是通過關聯幾張表查詢出來的&#xff0c;查詢出來的數據結果集一共是6個字段。要求傳輸的時候拆分成一個個小文件&#xff0c;每個文件大小不能超過500M。我的測試…

FuTalk設計周刊-Vol.052

#AI漫談 熱點捕手 1.ChatGPT 大更新&#xff01;GPT-4 開始又變聰明了 OpenAI 官方宣布&#xff0c;新版 GPT-4 Turbo 今天開始向所有付費 ChatGPT 用戶開放。 鏈接https://www.pconline.com.cn/focus/1733/17330089.html 2.刷爆多模態任務榜單&#xff01;賈佳亞團隊Mini-G…

Linux下環境變量配置出錯導致基礎命令使用不了的問題解決

問題&#xff1a; 當配置環境變量&#xff1a; echo export PATH/home/ubuntu/.local/lib/python3.8/site-packages :$PATH >> ~/.bashrc 執行生效命令 source ~/.bashrc 出現所有的基礎操作命令&#xff1a;ls vim都使用不了 解決方式&#xff1a; 1&#xff09…

21.2zabbix低級自動發現-mysql多實例

配置mysql多實例 注釋&#xff1a;自動發現&#xff1a;創建監控主機&#xff1b;低級自動發現&#xff1a;創建監控項 mysql單實例是直接yum安裝&#xff0c;開啟mysql多實例 準備配置文件 #mysql3307實例 cp /etc/my.cnf /etc/my3307.cnf vim /etc/my3307.cnf [mysqld] dat…

lazarus-IDE 可以開發 Node.js 嗎?

Lazarus IDE 本身不是用來開發 Node.js 應用程序的工具&#xff0c;因為它是一個用于開發跨平臺應用程序的環境&#xff0c;類似于 C Builder 或 Delphi。Node.js 是一個基于 JavaScript 的運行時環境&#xff0c;通常使用 V8 引擎&#xff0c;用于構建異步、事件驅動的服務器端…

產品經理-流程圖結構圖(四)

1. 流程圖 1.1 概念 為了達到特定的目標而進行的一系列有邏輯性的操作步驟&#xff0c;由兩個及以上的步驟&#xff0c;完成一個完整的行為的過程&#xff0c;可稱之為流程 1.2 產品經理為什么需要繪制流程圖&#xff1f; 保證產品的使用邏輯合理順暢向項目組其他成員清晰的…

代碼隨想錄算法訓練營Day4|24. 兩兩交換鏈表中的節點、19.刪除鏈表的倒數第N個節點、 142.環形鏈表II、面試題 02.07. 鏈表相交

24. 兩兩交換鏈表中的節點 這道題的關鍵在于: 1、在置換兩個節點的時候&#xff0c;當前節點需要在這倆節點之前一個節點。并且要提前保存cur.next以及cur.next.next。 2、每次置換完一組節點&#xff0c;cur cur.next.next 3、判斷結束的標志&#xff1a;奇數個節點&#xf…

如何禁止U盤拷貝文件|禁止U盤使用的軟件有哪些

禁止U盤拷貝文件的方法有很多&#xff0c;比如使用注冊表、組策略編輯器等&#xff0c;但這些方法都適合個人&#xff0c;不適合企業&#xff0c;因為企業需要對下屬多臺電腦進行遠程管控&#xff0c;需要方便、省時、省力的方法。目前來說&#xff0c;最好的方法就是使用第三方…

Unity websocket客戶端

&#x1f3c6; 個人愚見&#xff0c;沒事寫寫筆記 &#x1f3c6;《博客內容》&#xff1a;Unity3D開發內容 &#x1f3c6;&#x1f389;歡迎 &#x1f44d;點贊?評論?收藏 &#x1f50e;目標&#xff1a;服務器和客戶端可以實時的傳輸信息 ??實現目標&#xff1a; 使用的w…

技術速遞|無障礙應用程序之旅:鍵盤可訪問性和 .NET MAUI

作者&#xff1a;Rachel Kang 排版&#xff1a;Alan Wang 首先讓我們一起來看看您的應用程序是否支持鍵盤訪問&#xff1a; 啟動您的其中一個應用。如果您的設備尚未連接物理鍵盤&#xff0c;請連接物理鍵盤。像平常一樣導航您的應用程序&#xff0c;并且僅使用鍵盤來執行此操…

如何使用Rust構建Python原生庫?注意,不是動態鏈接庫!!!

參考文檔&#xff1a;https://github.com/PyO3/pyo3 創建python虛擬環境&#xff1a; conda create --name pyo3 python3.11.7激活虛擬環境&#xff1a; conda activate pyo3安裝依賴&#xff1a; pip install maturin初始化項目&#xff1a; maturin init構建項目&#x…

設計模式--目錄

設計模式是軟件工程中為解決常見問題而總結出來的一系列通用解決方案。它們可以分為三大類別&#xff1a;創建型模式、結構型模式和行為型模式。下面列舉了一些常見的設計模式及其分類&#xff1a; 創建型模式(Creational Patterns) 創建型模式關注對象的創建過程&#xff0c…

小程序checkbox改成圓形與radio樣式保持一致

修改前 修改后 html: <view class"agreement"><checkbox value"{{ isAgreed }}" bind:tap"toggleCheckbox" /><text>我同意室外智能健身房 <text class"link" bind:tap"showUserProtocol">用戶協…

【JTS Topology Suite】Java對二維幾何進行平移、縮放、旋轉等坐標變換

JTS介紹 Github項目地址&#xff1a;https://github.com/locationtech/jts Maven庫地址&#xff1a;https://mvnrepository.com/artifact/org.locationtech.jts JTS Topology Suite是一個用于創建和操作二維矢量幾何的Java庫。 JTS有對應的.NET版本NetTopologySuite庫&…

P3128 [USACO15DEC] Max Flow P題解(樹上差分,最近公共祖先,圖論)

前言&#xff1a; 題目鏈接&#xff1a;P3128 [USACO15DEC] Max Flow P - 洛谷 | 計算機科學教育新生態 (luogu.com.cn) 講解&#xff1a; 這一題含金量真算高的&#xff0c;包含了建樹&#xff08;用了圖論的知識&#xff09;&#xff0c;求最近公共祖先&#xff08;倍增法…

2024目前網上最火短劇機器人做法,自動搜索發劇 自動更新資源 自動分享資源

目前整個項目圈子很多的短劇機器人&#xff0c;我寫的&#xff0c;自動搜索發劇&#xff0c;自動更新資源&#xff0c;自動分享資源&#xff0c;前段時間大部分做短劇的都是做的短劇分成&#xff0c;我的一個學員做的30W播放量才200塊收益&#xff0c;備受啟發&#xff0c;我就…