亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

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

OJ 7219 復雜的整數劃分問題__動態規劃

2019-11-14 08:44:02
字體:
來源:轉載
供稿:網友

描述

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

輸入

標準的輸入包含若干組測試數據。每組測試數據是一行輸入數據,包括兩個整數N 和 K。 (0 < N <= 50, 0 < K <= N)

輸出

對于每組測試數據,輸出以下三行數據: 第一行: N劃分成K個正整數之和的劃分數目 第二行: N劃分成若干個不同正整數之和的劃分數目 第三行: N劃分成若干個奇正整數之和的劃分數目

樣例輸入

5 2

樣例輸出

2 3 3

提示 第一行: 4+1, 3+2, 第二行: 5,4+1,3+2 第三行: 5,1+1+3, 1+1+1+1+1+1

分析

整數劃分問題這幾個變形確實很經典,需要一個個說明下: 設dp[n][m]表示數n劃分方案中,每個數 不大于m 的劃分數。

N劃分成若干個可相同正整數之和

劃分分兩種情況:

劃分中每個數都小于m:則劃分數為dp[n][m-1]。劃分中至少有一個數等于m:則從n中減去去m,然后從n-m中再劃分,則劃分數為dp[n-m][m]。

動態轉移方程:dp[n][m]=dp[n][m-1]+dp[n-m][m]。

N劃分成若干個不同正整數之和

劃分分兩種情況:

劃分中每個數都小于m:則劃分數為dp[n][m-1]。劃分中至少有一個數等于m:則從n中減去m,然后從n-m中再劃分,且再劃分的數中每個數要小于m, 則劃分數為dp[n-m][m-1]。

動態轉移方程:dp[n][m]=dp[n][m-1]+dp[n-m][m-1]。

N劃分成K個正整數之和

設dp[n][k]表示數n劃分成k個正整數之和時的劃分數。 劃分分兩種情況:

劃分中不包含1:則要求每個數都大于1,可以先拿出k個1分到每一份,之后在n-k中再劃分k份,即dp[n-k][k]。劃分中包含1:則從n中減去1,然后從n-1中再劃分k-1份, 則劃分數為dp[n-1][k-1]。

動態轉移方程:dp[n][k]=dp[n-k][k]+dp[n-1][k-1]。

N劃分成若干個奇正整數之和

設f[i][j]表示將數i分成j個正奇數,g[i][j]表示將數i分成j個正偶數。 首先如果先給j個劃分每個分個1,因為奇數加1即為偶數,所以可得: f[i-j][j] = g[i][j]。 劃分分兩種情況:

劃分中不包含1:則要求每個數都大于1,可以先拿出k個1分到每一份,剛可將問題轉換為”從i-j中劃分j個偶數”,即g[i-j][j]。劃分中包含1:則從n中減去1,然后從n-1中再劃分k-1份, 則劃分數為dp[n-1][k-1]。

動態轉移方程:f[i][j]=f[i-1][j-1]+g[i-j][j]。

實現

#include <iostream>#include <cstring>using namespace std;#define N 51int dp1[N][N]; //N劃分成K個正整數之和的劃分數目。int dp2[N][N]; //N劃分成若干個不同正整數之和的劃分數目。int dp3[N][N]; //N劃分成若干個可相同的正整數之和的劃分數目。int f[N][N]; //N劃分成K個奇正整數之和的劃分數目。int g[N][N]; //N劃分成K個偶正整數之和的劃分數目。void initDivideInt() { memset(dp1, 0, sizeof(dp1)); //dp[n][k]=dp[n-k][k]+dp[n-1][k-1] memset(dp2, 0, sizeof(dp2)); //dp[n][m]=dp[n][m-1]+dp[n-m][m-1] memset(dp3, 0, sizeof(dp3)); //dp[n][m]=dp[n][m-1]+dp[n-m][m] for (int i = 1; i < N; i++) { for (int j = 1; j < N; j++) { if (i < j) { dp1[i][j] = 0; dp2[i][j] = dp2[i][i]; dp3[i][j] = dp3[i][i]; } else if (i == j) { dp1[i][j] = 1; dp2[i][j] = dp2[i][j - 1] + 1; dp3[i][j] = dp3[i][j - 1] + 1; } else { dp1[i][j] = dp1[i - j][j] + dp1[i - 1][j - 1]; dp2[i][j] = dp2[i][j - 1] + dp2[i - j][j - 1]; dp3[i][j] = dp3[i][j - 1] + dp3[i - j][j]; } } }}//f[i][j]=f[i-1][j-1]+g[i-j][j]void initDivideOdd() { f[0][0] = 1; g[0][0] = 1; for (int i = 1; i < N; i++) { for (int j = 1; j <= i; j++) { g[i][j] = f[i - j][j]; f[i][j] = f[i - 1][j - 1] + g[i - j][j]; } }}int main() {// freopen("in.txt", "r", stdin); int n, k; initDivideInt(); initDivideOdd(); while (cin >> n >> k) { cout << dp1[n][k] << endl; cout << dp2[n][n] << endl; int sum = 0; for (int i = 0; i <= n; i++) { sum += f[n][i]; } cout << sum << endl; } return 0;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品久久久一区二区三区| 亚洲一区免费网站| 日韩成人在线视频网站| 欧美人与性动交| 亚洲区在线播放| 欧美丰满老妇厨房牲生活| 97在线视频精品| 欧美日韩在线影院| 91久久夜色精品国产网站| 久久久久久久久久久久av| 日韩视频中文字幕| 欧美重口另类videos人妖| 日韩欧美在线第一页| 久久久久久久激情视频| 91精品视频在线| 久久九九有精品国产23| 亚洲成人动漫在线播放| 91久久久精品| 91中文字幕在线观看| 精品成人国产在线观看男人呻吟| 欧美电影在线观看| 亚洲人成亚洲人成在线观看| 日韩在线观看av| 欧美日韩成人精品| 亚洲国模精品私拍| 91亚洲精华国产精华| 久久亚洲影音av资源网| 亚洲人成在线播放| 国产日韩av高清| 精品欧美aⅴ在线网站| 欧美日韩免费网站| 亚洲一区二区三区久久| 日韩在线视频线视频免费网站| 国产网站欧美日韩免费精品在线观看| 2019精品视频| 成人av.网址在线网站| 18一19gay欧美视频网站| 久久精品国产清自在天天线| 伊人伊成久久人综合网站| 久久久精品免费| 亚洲第一区第二区| 91香蕉国产在线观看| 久久精品亚洲精品| 色无极亚洲影院| 5278欧美一区二区三区| 国产精品国产自产拍高清av水多| 国产精品高潮呻吟久久av无限| 欧美日韩亚洲一区二区| 91精品在线播放| 久久综合久中文字幕青草| 亚洲天堂男人的天堂| 日韩高清欧美高清| 奇米成人av国产一区二区三区| 国产精品视频一区二区三区四| 精品人伦一区二区三区蜜桃网站| 欧美大尺度激情区在线播放| 亚洲色图13p| 欧美在线一区二区三区四| 国产一区二区三区丝袜| 欧美裸体男粗大视频在线观看| 久久精品国产久精国产思思| 色偷偷综合社区| 狠狠躁夜夜躁人人爽天天天天97| 欧美在线www| 中文字幕欧美精品在线| 色狠狠久久aa北条麻妃| 久久天天躁夜夜躁狠狠躁2022| 亚洲va国产va天堂va久久| 久久综合久久八八| 国产午夜精品全部视频播放| 久久精品国产精品| www.日韩系列| 欧美高清自拍一区| 在线观看日韩www视频免费| 欧美精品videosex性欧美| 国产成人高清激情视频在线观看| 中文字幕成人在线| 亚洲精品一区二区三区不| 九色成人免费视频| 欧美一级高清免费| 亚洲欧美国产精品| 7m精品福利视频导航| 国产精品第2页| 91国内产香蕉| 国产日韩欧美在线播放| 欧美日韩一区二区在线| 欧美激情亚洲另类| 日韩中文综合网| 亚洲国产成人久久综合一区| 亚洲一区二区少妇| 亚洲精品av在线播放| 日韩av在线播放资源| 国产精品av在线播放| 国产盗摄xxxx视频xxx69| 国产精品久久久久久网站| 成人性生交大片免费观看嘿嘿视频| 国产精品丝袜白浆摸在线| 亚洲精品98久久久久久中文字幕| 91久久精品美女| 日韩免费中文字幕| 1769国内精品视频在线播放| 欧美国产日韩一区| 日韩一区二区精品视频| 国产成人精品综合久久久| 在线视频欧美日韩| 久久av中文字幕| 亚洲四色影视在线观看| 精品久久久久久久久久国产| 日韩视频在线免费| 国产精品露脸av在线| 亚洲天堂精品在线| 欧美成人免费全部| 亚洲成人性视频| 欧洲亚洲免费视频| 隔壁老王国产在线精品| 中文字幕亚洲综合久久筱田步美| 成人在线国产精品| 欧美性高潮床叫视频| 伊人青青综合网站| 亚洲欧美日韩中文视频| 精品亚洲一区二区三区在线观看| 精品一区电影国产| 成人午夜两性视频| 亚洲人成毛片在线播放| 亚洲a在线观看| 国产欧美日韩精品丝袜高跟鞋| 日韩av中文字幕在线| 日本国产欧美一区二区三区| 亚洲精品456在线播放狼人| 欧美激情xxxxx| 国产精品情侣自拍| 日韩大片在线观看视频| 欧美激情亚洲另类| 91久久中文字幕| 亚洲成av人片在线观看香蕉| 色综合天天综合网国产成人网| 日韩在线观看视频免费| 欧美多人爱爱视频网站| 欧美在线观看日本一区| 亚洲国产成人久久| 亚洲欧美日韩在线一区| 国外视频精品毛片| 亚洲激情视频在线播放| 136fldh精品导航福利| 成人激情在线播放| 久久综合伊人77777蜜臀| 日韩中文有码在线视频| 国产一区二区丝袜| 欧美人成在线视频| 欧美成人免费观看| 久热在线中文字幕色999舞| 日本精品va在线观看| 最近的2019中文字幕免费一页| 中文字幕国产精品| 色妞色视频一区二区三区四区| 国产日韩欧美91| 国外成人在线直播| 91九色精品视频| 国产精品国产三级国产aⅴ浪潮| 亚洲精品ady| 狠狠躁18三区二区一区| 亚洲区一区二区| 久久久精品久久久| 国产精品久久久久久av福利软件|