C語言重構 279 完全平方數

2021-10-22 03:28:42 字數 691 閱讀 9389

所有題目源**:git位址

題目

給定正整數 n,找到若干個完全平方數(比如 1,4

,9,16

,...)使得它們的和等於 n。你需要讓組成和的完全平方數的個數最少。

給你乙個整數 n ,返回和為 n 的完全平方數的 最少數量 。

完全平方數 是乙個整數,其值等於另乙個整數的平方;換句話說,其值等於乙個整數自乘的積。例如,1、4、9 和 16 都是完全平方數,而 3 和 11 不是。

示例 1:

輸入:n =

12輸出:3

解釋:12=4

+4+4

示例 2:

輸入:n =

13輸出:2

解釋:13=4

+9 1

<= n <=

104

方案:
class

solution

vector<

int>

sqnum

(n,0);

//初始化平方數

int k =1;

while

(sqnum[k -1]

<= n)

for(

int i =

4; i <= n; i++)}

return dp[n];}

};

複雜度計算

279 完全平方數

給定正整數 n,找到若干個完全平方數 比如 1,4,9,16,使得它們的和等於 n。你需要讓組成和的完全平方數的個數最少。示例 1 輸入 n 12 輸出 3 解釋 12 4 4 4.示例 2 輸入 n 13 輸出 2 解釋 13 4 9.其中dp i 表示正整數i最少能由多個完全平方數組成,那麼我們...

279 完全平方數

給定正整數 n,找到若干個完全平方數 比如1,4,9,16,使得它們的和等於n。你需要讓組成和的完全平方數的個數最少。示例 1 輸入 n 12輸出 3解釋 12 4 4 4.示例 2 輸入 n 13輸出 2解釋 13 4 9.動態規劃 class solution return dp n 使用佇列輔...

279 完全平方數

include include include using namespace std class solution return res int main 把這個問題轉換為乙個無權圖找最短路徑以後,因為有很多路徑可以到達乙個同乙個節點 12 1 11 4 7 12 4 8 1 7 比如12就可以通...