LeetCode 651. 4鍵鍵盤(DP,Ctrl+CV)

文章目錄

1. 題目

假設你有一個特殊的鍵盤包含下面的按鍵:

Key 1: (A):在屏幕上打印一個 'A'。

Key 2: (Ctrl-A):選中整個屏幕。

Key 3: (Ctrl-C):複製選中區域到緩衝區。

Key 4: (Ctrl-V):將緩衝區內容輸出到上次輸入的結束位置,並顯示在屏幕上。

現在,你只可以按鍵 N 次(使用上述四種按鍵),請問屏幕上最多可以顯示幾個 'A’呢?

樣例 1:
輸入: N = 3
輸出: 3
解釋: 
我們最多可以在屏幕上顯示三個'A'通過如下順序按鍵:
A, A, A
 
樣例 2:
輸入: N = 7
輸出: 9
解釋: 
我們最多可以在屏幕上顯示九個'A'通過如下順序按鍵:
A, A, A, Ctrl A, Ctrl C, Ctrl V, Ctrl V
註釋:
1 <= N <= 50
結果不會超過 32 位有符號整數範圍。

來源:力扣(LeetCode) 鏈接:https://leetcode-cn.com/problems/4-keys-keyboard
著作權歸領釦網絡所有。商業轉載請聯繫官方授權,非商業轉載請註明出處。

2. 解題

在這裏插入圖片描述

  • 只按一個鍵A,直接在前一個狀態的個數+1
  • 按ACV的話,可以從前面所有可能的位置ACV一次以後,一直VVV
  • 可以粘貼以後,VVV好於ACV,但是ACVV 好於VVVV(數量一樣,但是前者粘貼板的A數量多)

在這裏插入圖片描述
在這裏插入圖片描述

class Solution {
public:
    int maxA(int N) {
    	vector<int> dp(N+1,0);
    	//dp[i] 表示,第 i 次按下鍵的最多A個數
    	for(int i = 1, j; i <= N; ++i)
    	{
    		dp[i] = max(dp[i], dp[i-1]+1);//按下A鍵
    		for(j = 0; j <= i-2; ++j)
    		//從前面可以的地方選一次進行ACV,後面一直V...
    		// -2 表示 AC的少了2次,後面可以一直粘(i-j-2)次 + 原來自己一次
    			dp[i] = max(dp[i], dp[j]*(i-j-1));
    	}
    	return dp[N];
    }
};

0 ms 6.1 MB


我的CSDN博客地址 https://michael.blog.csdn.net/

長按或掃碼關注我的公衆號(Michael阿明),一起加油、一起學習進步!
Michael阿明

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章