牛客算法竞赛题解

发布时间:2024年01月03日

文章目录

[NOIP2001]数的划分

DFS

#include<bits/stdc++.h>
using namespace std;
int n,k,res;
struct Num {
    int now,cnt;
};
void DFS(Num num,int pos) {//DFS遍历
    if(num.cnt==1&&num.now>=pos) {//最后一次递归的时候
        ++res;
        return ;
    }
    for(int i=(pos?pos:1); i<=num.now; ++i) {//按照单调不减序列排
        DFS({num.now-i,num.cnt-1},i);//递归为将now-i这个数划分为cnt-i份,每份不为空
    }
}
int main() {
    scanf("%d%d",&n,&k);
    DFS({n,k},0);
    printf("%d\n",res);
}

动态规划

#include<bits/stdc++.h>
using namespace std;
#define M 500
int n,k;
int dp[M][M];
void init() {
    for(int i=1; i<=n; ++i) {
        dp[i][1]=1;//dp初始化
    }
}
int main() {
    scanf("%d%d",&n,&k);
    init();
    for(int i=2; i<=n; ++i) {
        for(int j=2; j<=k; ++j) {
            if(i>j)dp[i][j]=dp[i-1][j-1]+dp[i-j][j];//先对j个分块预置为1
            else dp[i][j]=dp[i-1][j-1];//依次拿一个数出来
        }
    }
    printf("%d\n",dp[n][k]);
}
文章来源:https://blog.csdn.net/qq_51201910/article/details/135352052
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。