codevs 1039:数的划分

http://codevs.cn/problem/1039/

题目描述 Description
将整数n分成k份,且每份不能为空,任意两种划分方案不能相同(不考虑顺序)。
例如:n=7,k=3,下面三种划分方案被认为是相同的。
1 1 5

1 5 1

5 1 1
问有多少种不同的分法。

输入描述 Input Description
输入:n,k (6<n<=200,2<=k<=6)

输出描述 Output Description

输出:一个整数,即不同的分法。

样例输入 Sample Input
7 3

样例输出 Sample Output
4

数据范围及提示 Data Size & Hint
{四种分法为:1,1,5;1,2,4;1,3,3;2,2,3;}

芒果君:学DP也有一阵子了,然而这个简单的划分型DP还是不太会写,主要是没有思路OTZ……这道题学递归的时候写过,然而用DP的话就很茫然,看完题解,我的理解是酱紫的,首先这个状态转移方程分为两部分,第一部分:F[i-j][j],就是现在k个位置上铺一层"1",然后再把i-j个数分成j份的方案“搭”在上面,这样就涵盖了所有“每一位都不为1”的方案,剩下的就是第二部分:F[i-1][j-1],意思是先把"1"放在第1位上,剩下i-1个数分成j份。需要注意的是,你在一开始要初始化i个数分成1份,方案数是1,还要照顾到F[1][1],所以把F[0][0]置成1。哦对了!i>=j的时候才是有意义的。

#include<cstdio>
using namespace std;
int f[210][8],n,k,i,j;
int main()
{
    scanf("%d%d",&n,&k);
    f[0][0]=1;
    for(i=1;i<=n;++i)
    {
        f[i][1]=1;
    }
    for(i=1;i<=n;++i)
    {
        for(j=1;j<=k;++j)
        {
             if(i>=j)
             {
                 f[i][j]=f[i-j][j]+f[i-1][j-1];
             }
        }
    }
    printf("%d",f[n][k]);
    return 0;
}
时间: 2024-12-10 12:05:35

codevs 1039:数的划分的相关文章

codevs 1039 数的划分 x

1039 数的划分 2001年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 将整数n分成k份,且每份不能为空,任意两种划分方案不能相同(不考虑顺序).例如:n=7,k=3,下面三种划分方案被认为是相同的.1 1 5 1 5 1 5 1 1问有多少种不同的分法. 输入描述 Input Description 输入:n,k (6<n<=200,2<=k<=6) 输出描述 Output Desc

codevs——1039 数的划分

1039 数的划分 2001年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题解 题目描述 Description 将整数n分成k份,且每份不能为空,任意两种划分方案不能相同(不考虑顺序).例如:n=7,k=3,下面三种划分方案被认为是相同的.1 1 5 1 5 1 5 1 1问有多少种不同的分法. 输入描述 Input Description 输入:n,k (6<n<=200,2<=k<=6) 输出描述 Output D

luoguP1025+codevs 1039 数的划分 x

luoguP1025 + codevs1039 数的划分 2001年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 将整数n分成k份,且每份不能为空,任意两种划分方案不能相同(不考虑顺序).例如:n=7,k=3,下面三种划分方案被认为是相同的.1 1 5 1 5 1 5 1 1问有多少种不同的分法. 输入描述 Input Description 输入:n,k (6<n<=200,2<=k<=

划分型动态规划 之 CODE[VS] 1039 数的划分 2001年NOIP全国联赛提高组

/* dp[i][k] := 将整数i分成k份,分法种数 初始化: dp[][] = { 0 } dp[i][1] = 1 状态方程: dp[i][k] = dp[i-1][k-1] + dp[i-k][k] 思想:(引自byvoid大神的博客:https://www.byvoid.com/blog/noip-allsolutions#.E6.95.B0.E7.9A.84.E5.88.92.E5.88.86) 每种拆分方案中,最小的数为w,按照w的不同,我们可以把拆分方案分成2类: w=1,我们

NOIP2001 数的划分

题二 数的划分(20分) 问题描述 将整数n分成k份,且每份不能为空,任意两份不能相同(不考虑顺序). 例如:n=7,k=3,下面三种分法被认为是相同的. 1,1,5; 1,5,1; 5,1,1; 问有多少种不同的分法. 输入:n,k (6<n<=200,2<=k<=6) 输出:一个整数,即不同的分法. 样例 输入: 7 3 输出:4 {四种分法为:1,1,5;1,2,4;1,3,3;2,2,3;} [思路] 递推. 递推式d[i][j]=d[i-1][j-1]+d[i-j][j]

C语言 &#183; 数的划分

算法提高 数的划分 时间限制:1.0s   内存限制:256.0MB 问题描述 一个正整数可以划分为多个正整数的和,比如n=3时: 3:1+2:1+1+1: 共有三种划分方法. 给出一个正整数,问有多少种划分方法. 输入格式 一个正整数n 输出格式 一个正整数,表示划分方案数 样例输入 3 样例输出 3 数据规模和约定 n<=100 作者注释:递归问题.(本题运行超时) step表示当前剩余的数需要分成的份数;把n分成k份,只需第一个数等于i,计算从i等于1一直到i等于n/k,然后把剩余的n-i

数的划分(动规)

数的划分 总时间限制:  1000ms 内存限制:  65536kB 描述 将整数n分成k份,且每份不能为空,任意两份不能相同(不考虑顺序). 例如:n=7,k=3,下面三种分法被认为是相同的. 1,1,5: 1,5,1: 5,1,1: 问有多少种不同的分法. 输出:一个整数,即不同的分法. 输入 两个整数n,k (6 < n <= 200,2 <= k <= 6),中间用单个空格隔开. 输出 一个整数,即不同的分法. 样例输入 7 3 样例输出 4 提示 四种分法为:1,1,5:

1039: 数的距离差

1039: 数的距离差 时间限制: 1 Sec  内存限制: 128 MB提交: 199  解决: 182[提交][状态][讨论版] 题目描述 给定一组正整数,其中最大值和最小值分别为Max和Min, 其中一个数x到Max和Min的距离差定义为: abs(abs(x-Max)-(x-Min) 其中abs()为求一个数的绝对值 输入 包括两行,第一行一个数n,表示第二行有n个正整数 输出 输出一个数x,该数在所有n个数中的距离差最小 样例输入 5 3 1 7 5 9 样例输出 5 提示 来源 #i

8787:数的划分(又是一个放苹果)

8787:数的划分 查看 提交 统计 提问 总时间限制: 1000ms 内存限制: 65536kB 描述 将整数n分成k份,且每份不能为空,任意两份不能相同(不考虑顺序). 例如:n=7,k=3,下面三种分法被认为是相同的. 1,1,5: 1,5,1: 5,1,1: 问有多少种不同的分法. 输出:一个整数,即不同的分法. 输入 两个整数n,k (6 < n <= 200,2 <= k <= 6),中间用单个空格隔开. 输出 一个整数,即不同的分法. 样例输入 7 3 样例输出 4

JDFZ 1112 高三楼 数的划分

题意:链接 方法:数的划分 解析: 我终于A了这道题了!! 百年老坑!!!!!! 首先我承认这个玩意暴力我都不会写. 或者暴力复杂度爆炸. 看上面这个图,这是个7*7的矩阵 显然他可以由2,2,3来表示(RT); 但是这里它划分出来的三个矩阵的表示方法必须是独有的. 什么是独有的呢?以边长为4的矩阵演示一下. 显然有两种填充方案.如下图. 但是第一种填充方案显然是由两个边长为2的矩阵构成的,不是他独有的方案. 第二种填充方案便是它独有的填充方案,因为在这种填充方案中.找不到一个大小为i(i 因为