解题思路:
这是优化后的代码通过滚动数组优化
注意事项:
参考代码:
#include <bits/stdc++.h> using namespace std; int dp[1000]; int main(){ int n; cin>>n; dp[0]=1; for(int i=1;i<=n;i++){ // i相当于物品的重量 for(int j=1;j<=n;j++){ //n代表了背包的容量 和 物品的数量 每件物品无限取 if(j>=i) dp[j]=dp[j]+dp[j-i]; } } cout<<dp[n]; return 0; }
0.0分
0 人评分