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

首頁 > 學院 > 開發設計 > 正文

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

2019-11-11 00:48:57
字體:
來源:轉載
供稿:網友
總時間限制: 100ms 內存限制: 65536kB描述

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

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

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

思路:

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 金川县| 宜宾市| 阜康市| 沙洋县| 襄垣县| 鹰潭市| 兰西县| 河池市| 瓮安县| 巴塘县| 红河县| 广宁县| 临夏县| 嵊泗县| 鲁甸县| 仲巴县| 马尔康县| 应用必备| 大化| 涞水县| 伊通| 贺兰县| 西宁市| 万源市| 鄂尔多斯市| 比如县| 嘉善县| 纳雍县| 介休市| 天门市| 交城县| 乌兰浩特市| 鸡东县| 扬州市| 青阳县| 阿勒泰市| 大方县| 铜山县| 常德市| 密云县| 来凤县|