DP

对于由从1到N (1 <= N <= 39)这N个连续的整数组成的集合来说,我们有时可以将集合分成两个部分和相同的子集合。
例如,N=3时,可以将集合{1, 2, 3} 分为{1,2}和{3}。此时称有一种方式(即与顺序无关)。
N=7时,共有四种方式可以将集合{1, 2, 3, ..., 7} 分为两个部分和相同的子集合:
{1,6,7} 和 {2,3,4,5} 
{2,5,7} 和 {1,3,4,6} 
{3,4,7} 和 {1,2,5,6} 
{1,2,4,7} 和 {3,5,6} 
输入:程序从标准输入读入数据,只有一组测试用例。如上所述的N。
输出:方式数。若不存在这样的拆分,则输出0。

 测试输入期待的输出时间限制内存限制额外进程
测试用例 1以文本方式显示
  1. 7↵
以文本方式显示
  1. 4↵
1秒64M0
#include<iostream>
#include<cstdio> 
using namespace std;

int dp[1000]={1}; //第一个值初始化为1 

int main(){
	int n;
	scanf("%d",&n);
	if(n*(n+1)%4)
	{
		printf("0\n");
		return 0;
	}
	int hs=n*(n+1)/4; //总和的一半 
	for(int i=1;i<=n;++i)
	{
		for(int j=hs;j>=i;--j) //更新组成和为j的组数 
		{
			dp[j]+=dp[j-i];
			//cout<<j<<" "<<dp[j]<<endl;
		}
	}
	printf("%d\n",dp[hs]/2); //去掉重复的一半
	return 0; 
} 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值