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

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

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

2019-11-14 09:12:53
字體:
來源:轉載
供稿:網友

描述

將正整數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
欧美中文在线免费| 久久综合久久88| 黄网站色欧美视频| 成人高清视频观看www| 久久久之久亚州精品露出| 国产精品嫩草影院久久久| 国内精品久久久久久久| 伊人激情综合网| 国产精品视频自拍| 精品久久久久久久久久ntr影视| 亚洲级视频在线观看免费1级| 中文字幕在线看视频国产欧美| 91久久久久久久| 日韩在线免费观看视频| 国产精品免费一区| 26uuu另类亚洲欧美日本老年| 亚洲国产精品福利| 热re99久久精品国产66热| 日韩精品免费在线播放| 成人免费福利在线| 自拍偷拍亚洲一区| 国产精品久久久999| 国产精品一区=区| 国产精品自产拍在线观看中文| 久久久免费精品| 亚洲欧美三级伦理| 亚洲国产精品电影在线观看| 国产噜噜噜噜噜久久久久久久久| 中文字幕久热精品在线视频| 69影院欧美专区视频| 欧美性生活大片免费观看网址| 久久91超碰青草是什么| 欧美成人性色生活仑片| 亚洲人成网站在线播| 久久夜精品va视频免费观看| 亚洲成人激情在线| 日韩黄色高清视频| 韩剧1988免费观看全集| 蜜臀久久99精品久久久无需会员| 日韩视频第一页| 午夜精品在线视频| 欧美激情视频一区二区| 欧美成人午夜激情视频| 日本欧美在线视频| 国产女精品视频网站免费| 久久九九免费视频| 欧美性xxxx极品高清hd直播| 91在线观看免费高清完整版在线观看| 国产精品黄色影片导航在线观看| 日韩高清a**址| 欧美日韩ab片| 欧美成人全部免费| 欧美日韩国产123| 国产精品视频1区| 欧美成人一区二区三区电影| 91精品国产乱码久久久久久久久| 久久精品国产96久久久香蕉| 在线精品视频视频中文字幕| 亚洲精品国产精品国产自| 国产精品99久久久久久www| 97国产精品视频| 欧美影院成年免费版| 免费不卡欧美自拍视频| 久久天天躁狠狠躁夜夜躁| 亚洲精品天天看| 亚洲伊人久久综合| 最近日韩中文字幕中文| 精品亚洲一区二区三区在线观看| 91tv亚洲精品香蕉国产一区7ujn| 亚洲系列中文字幕| 97成人精品视频在线观看| 91精品国产色综合久久不卡98| 欧美小视频在线| 91精品国产成人| 不卡av电影在线观看| 国产视频精品免费播放| 性色av一区二区三区在线观看| 日韩精品中文字幕久久臀| 日韩av电影手机在线| 成人亚洲欧美一区二区三区| 26uuu另类亚洲欧美日本一| 中文字幕精品—区二区| 亚洲国产天堂久久综合网| 亚洲精品99999| 欧美性猛交xxxx免费看久久久| 久久九九国产精品怡红院| 国产精品日日做人人爱| 国产精品偷伦视频免费观看国产| 在线观看国产精品日韩av| 国产亚洲一级高清| 亚洲女人初尝黑人巨大| 国产偷亚洲偷欧美偷精品| 第一福利永久视频精品| 国模叶桐国产精品一区| 国产一区二区色| 亚洲日本aⅴ片在线观看香蕉| 一区二区三区四区精品| 欧美激情久久久久| 国产精品精品久久久久久| 日韩精品在线免费| 国产欧美日韩高清| 国产精品海角社区在线观看| 日韩电影免费在线观看| 一区二区日韩精品| 精品国产电影一区| 色偷偷噜噜噜亚洲男人的天堂| 亚洲图片在线综合| 国产午夜精品一区二区三区| 久久亚洲国产精品成人av秋霞| 日韩视频亚洲视频| 亚洲精品永久免费精品| 国产精品白丝jk喷水视频一区| 欧美激情极品视频| 日韩免费看的电影电视剧大全| 97涩涩爰在线观看亚洲| 欧美巨乳在线观看| 日韩美女免费视频| 91亚洲精品在线观看| 啪一啪鲁一鲁2019在线视频| 精品福利视频导航| 欧美精品18videosex性欧美| 久久久久五月天| 精品亚洲一区二区三区四区五区| 日韩av免费在线看| 国产精品男人爽免费视频1| 日韩av中文字幕在线播放| 欧美二区在线播放| 亚洲激情中文字幕| 日韩av综合网| 2019精品视频| 欧美成人激情视频| 欧美成在线视频| 国产亚洲精品综合一区91| 日韩精品久久久久久久玫瑰园| 欧美一二三视频| 亚洲大胆人体视频| 欧美极品欧美精品欧美视频| 久久久久久国产精品久久| zzjj国产精品一区二区| 日韩精品视频在线观看网址| 97精品国产91久久久久久| 欧美激情二区三区| 午夜精品美女自拍福到在线| 久久网福利资源网站| 亚洲自拍在线观看| 亚洲高清不卡av| 欧美老少做受xxxx高潮| 国产91免费观看| 姬川优奈aav一区二区| 久久理论片午夜琪琪电影网| 欧美日本在线视频中文字字幕| 亚洲国产另类 国产精品国产免费| 国产美女精彩久久| 在线观看日韩av| 亚洲毛片一区二区| 在线播放日韩av| 日韩欧亚中文在线| 久久精品最新地址| 国产精品视频26uuu| 成人网在线视频| 色诱女教师一区二区三区| 中文字幕一区二区三区电影| 主播福利视频一区| 亚洲欧洲午夜一线一品|