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;	
} 
全部评论

相关推荐

苍蓝星上艾露:这简历。。。可以试试我写的开源简历优化工具https://github.com/weicanie/prisma-ai
点赞 评论 收藏
分享
湫湫湫不会java:先投着吧,大概率找不到实习,没实习的时候再加个项目,然后把个人评价和荣誉奖项删了,赶紧成为八股战神吧,没实习没学历,秋招机会估计不多,把握机会。或者说秋招时间去冲实习,春招冲offer,但是压力会比较大
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务