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

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

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

2019-11-11 00:51:24
字體:
來源:轉載
供稿:網友
總時間限制: 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;}


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 寻乌县| 洪洞县| 铜鼓县| 通榆县| 怀柔区| 新平| 林甸县| 顺平县| 遂宁市| 巨野县| 清原| 兴文县| 金塔县| 荣成市| 白山市| 松滋市| 仪征市| 固原市| 屏东市| 莒南县| 呼和浩特市| 南宫市| 昌图县| 阳高县| 怀安县| 永州市| 新龙县| 伊春市| 嘉荫县| 安达市| 疏勒县| 岢岚县| 锡林郭勒盟| 旌德县| 老河口市| 绥江县| 镇赉县| 犍为县| 永登县| 乌恰县| 凤庆县|