C ++中的完美方块
假设我们有一个正整数n,求和的总和为n的最小平方数最少。因此,如果数字为13,则输出为2,因为数字为13=9+4
为了解决这个问题,我们将遵循以下步骤-
创建一个用于动态编程的表,其长度为n+1,并用无穷大填充
dp[0]:=0
对于i:=1,当i*i<=n
dp[j]:=dp[j]和1+dp[j–x]的最小值
x=我*我
对于j:=x到n
返回dp[n]
让我们看下面的实现以更好地理解-
示例
#include <bits/stdc++.h>
using namespace std;
#define INF 1e9
class Solution {
public:
int numSquares(int n) {
vector < int > dp(n+1,INF);
dp[0] = 0;
for(int i =1;i*i<=n;i++){
int x = i*i;
for(int j = x;j<=n;j++){
dp[j] = min(dp[j],1+dp[j-x]);
}
}
return dp[n];
}
};
main(){
Solution ob;
cout << (ob.numSquares(147));
}输入值
147
输出结果
3
热门推荐
10 八一幼儿祝福语大全简短
11 公司乔迁食堂祝福语简短
12 婚礼结束聚餐祝福语简短
13 儿媳买车妈妈祝福语简短
14 毕业送礼老师祝福语简短
15 同事辞职正常祝福语简短
16 恭贺新婚文案祝福语简短
17 金店立秋祝福语简短英文
18 婆婆高寿祝福语大全简短