国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發(fā)設計 > 正文

OpenJudge 簡單的整數(shù)劃分問題(遞歸)

2019-11-10 23:50:25
字體:
供稿:網(wǎng)友
總時間限制: 100ms 內(nèi)存限制: 65536kB描述

將正整數(shù)n 表示成一系列正整數(shù)之和,n=n1+n2+…+nk, 其中n1>=n2>=…>=nk>=1 ,k>=1 。正整數(shù)n 的這種表示稱為正整數(shù)n 的劃分。正整數(shù)n 的不同的劃分個數(shù)稱為正整數(shù)n 的劃分數(shù)。

輸入標準的輸入包含若干組測試數(shù)據(jù)。每組測試數(shù)據(jù)是一個整數(shù)N(0 < N <= 50)。輸出對于每組測試數(shù)據(jù),輸出N的劃分數(shù)。樣例輸入
5樣例輸出
7提示

5, 4+1, 3+2, 3+1+1, 2+2+1, 2+1+1+1, 1+1+1+1+1

思路:

根據(jù)n和m的關系,考慮以下幾種情況:   (1)當n=1時,不論m的值為多少(m>0),只有一種劃分即{1};   (2)當m=1時,不論n的值為多少,只有一種劃分即n個1,{1,1,1,...,1};   (3)當n=m時,根據(jù)劃分中是否包含n,可以分為兩種情況:      (a)劃分中包含n的情況,只有一個即{n};      (b)劃分中不包含n的情況,這時劃分中最大的數(shù)字也一定比n小,即n的所有(n-1)劃分。      因此 f(n,n) =1 + f(n,n-1);   (4)當n<m時,由于劃分中不可能出現(xiàn)負數(shù),因此就相當于f(n,n);   (5)但n>m時,根據(jù)劃分中是否包含最大值m,可以分為兩種情況:       (a)劃分中包含m的情況,即{m, {x1,x2,...xi}}, 其中{x1,x2,... xi} 的和為n-m,因此這情況下          為f(n-m,m)       (b)劃分中不包含m的情況,則劃分中所有值都比m小,即n的(m-1)劃分,個數(shù)為f(n,m-1);      因此 f(n, m) = f(n-m, m)+f(n,m-1);      綜上所述:                             f(n, m)=   1;                    (n=1 or m=1)                             f(n,m)   =    f(n, n);         (n<m)                             1+ f(n, m-1);                  (n=m)                             f(n-m,m)+f(n,m-1);        (n>m)

代碼:

#include<iostream>using namespace std;int sp(int n,int m) {	if(n==1||m==1) return 1;	else if(n<m) return sp(n,n);	else if(n==m) return sp(n,n-1)+1;	else return sp(n,m-1)+sp(n-m,m);}int main() {	int n;	while(cin>>n) {		cout<<sp(n,n)<<endl;	}	return 0;}


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 花垣县| 宿州市| 清徐县| 永安市| 东兴市| 林口县| 三亚市| 商都县| 玉门市| 伊宁县| 苗栗市| 德令哈市| 加查县| 广平县| 阜宁县| 浙江省| 镇江市| 策勒县| 德昌县| 西平县| 永清县| 亚东县| 舒兰市| 始兴县| 方山县| 丰城市| 黄平县| 宁安市| 宁蒗| 张家口市| 安吉县| 苍梧县| 太仓市| 赣榆县| 古浪县| 临颍县| 佛坪县| 句容市| 阿尔山市| 临沭县| 泰安市|