J - Staircases (遞推&數的劃分)

J - Staircases (遞推&數的劃分)

題意:求有多少種不同數之和爲n的方案。(劃分個數大於1)

思路:
在這裏插入圖片描述

AC代碼:

#include<cstdio>
#include<cstring>
using namespace std;
const int N=5e2+5;
typedef long long ll;
ll dp[N][N];
int main(){
	int n;
	while(~scanf("%d",&n)){
		memset(dp,0,sizeof dp);
		for(int i=1;i<=n;i++) dp[i][i]=1;
		for(int i=2;i<=n;i++)
			for(int j=i-1;j>=1;j--)
				dp[i][j]=dp[i-j][j+1]+dp[i][j+1];
		printf("%lld\n",dp[n][1]-1);
	}
	return 0;
} 

附上一維代碼(PS:不太理解,貌似類似於揹包的降維)

#include<cstdio>
#include<cstring>
using namespace std;
const int N=5e2+5;
typedef long long ll;
ll dp[N];
int main(){
	int n;
	while(~scanf("%d",&n)){
		memset(dp,0,sizeof dp);
		dp[0]=1;
		for(int i=1;i<=n;i++)
			for(int j=n;j>=i;j--)
				dp[j]+=dp[j-i];
		printf("%lld\n",dp[n]-1);
	}
	return 0;	
} 
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章