赞
踩
将整数n分成k份,且每份不能为空,任意两份不能相同(不考虑顺序)。
例如:n=7,k=3,下面三种分法被认为是相同的。
1,1,5;
1,5,1;
5,1,1;
问有多少种不同的分法。
n k
一个整数,即不同的分法。
7 3
4
6<n<=200,2<=k<=6
样例中的四种分法为:1,1,5; 1,2,4; 1,3,3; 2,2,3;
noip2001提高组第2题
- #include<bits/stdc++.h>
- using namespace std;
- int n,a[225]={1},total,k;
- void dfs(int d,int h){
- // printf("%d %d \n",d,h);
- if(d-1==k){
- if(h==n){total++;}else return;
- }
- if(d>=k+1)return;
- if(h>n)return;
- for(int i=a[d-1];i<=(n-h)/(k-d+1);i++){
- // printf("%d ",d);
- a[d]=i;
- dfs(d+1,h+i);
- }return;
- }
- int main(){
- cin>>n>>k;
- dfs(1,0);
- printf("%d\n",total);
- }

Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。