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

首頁 > 編程 > C > 正文

C語言使用DP動態規劃思想解最大K乘積與乘積最大問題

2020-01-26 14:34:13
字體:
來源:轉載
供稿:網友

最大K乘積問題
設I是一個n位十進制整數。如果將I劃分為k段,則可得到k個整數。這k個整數的乘積稱為I的一個k乘積。試設計一個算法,對于給定的I和k,求出I的最大k乘積。
編程任務:
對于給定的I 和k,編程計算I 的最大k 乘積。
需求輸入:
輸入的第1 行中有2個正整數n和k。正整數n是序列的長度;正整數k是分割的段數。接下來的一行中是一個n位十進制整數。(n<=10)
需求輸出:
計算出的最大k乘積。

解題思路:DP
設w(h,k) 表示: 從第1位到第K位所組成的十進制數,設m(i,j)表示前i位(1-i)分成j段所得的最大乘積,則可得到如下經典的DP方程:

if(j==1) m(i,j) = w(1,i) ;if(j >=1 && j<=i) m(i,j) = max{m(d,j-1)*m(d+1,i)} 

其中: 1<=d< i (即從1開始一直到i-1 中找最大值

else if(i < j) m(i,j) = 0 ; 

代碼示例:
#include <stdio.h>#include <stdlib.h>#include <string.h>#define MAXN 51#define MAXK 10long m[MAXK][MAXN]={{0,0}} ; /*初始化操作*/long w[MAXN][MAXN]={{0,0}} ; void maxdp(int n,int k,int *a){  int i,j,d,h,q,t,s;  long temp,max;  for(i=1; i<= n ; i++) /*分成1段*/  m[i][1] = w[1][i];      for(i=1 ; i<= n ; i++) /* DP 過程*/  for(j=2; j<= k ; j++)  {    max = 0;     for(d=1; d < i ; d++)    if ( (temp = m[d][j-1]*w[d+1][i]) > max)      max = temp ;    m[i][j] = max ;          }  }      int main(void){ int n,k,i,j; int a[MAXN]={0},la=0; char c ; scanf("%d %d ",&n,&k);  while ( ( c=getchar() )!=' ') /*讀入數據*/ {   a[++la] = c-'0' ; }  for(i=1 ; i<= n; i++) {   w[i][i]= a[i] ;   for(j=i+1 ; j<= n; j++)   w[i][j] = w[i][j-1]*10 + a[j] ; }  /* for(i=1 ; i<= n; i++) {   for(j=1 ; j<= n; j++)   printf("%d ",w[i][j]);   printf(" "); } */  maxdp(n,k,a) ;  printf("%ld ",m[n][k]) ;  /*system("pause");*/  return 0;}


乘積最大問題:

(和最大k乘積問題差不多,都是用DP,不過有些細節要注意一下,比如:位數小于乘號,則為0)

描述 Description  
今年是國際數學聯盟確定的“2000――世界數學年”,又恰逢我國著名數學家華羅庚先生誕辰90周年。在華羅庚先生的家鄉江蘇金壇,組織了一場別開生面的數學智力競賽的活動,你的一個好朋友XZ也有幸得以參加?;顒又?,主持人給所有參加活動的選手出了這樣一道題目:
設有一個長度N的數字串,要求選手使用K個乘號將它分成K+1個部分,找出一種分法,使得這K+1個部分的乘積能夠為最大。
同時,為了幫助選手能夠正確理解題意,主持人還舉了如下的一個例子:
有一個數字串: 312,當N=3,K=1時會有以下兩種分法:
(1)3*12=36
(2)31*2=62
這時,符合題目要求的結果是:  31*2=62
現在,請你幫助你的好朋友XZ設計一個程序,求得正確的答案。
 輸入格式 Input Format 
程序的輸入共有兩行:
1.第一行共有2個自然數N,K (6<=N<=40,1<=K<=6)
2.第二行是一個K度為N的數字串。

輸出格式 Output Format 
屏幕輸出(結果顯示在屏幕上),相對于輸入,應輸出所求得的最大乘積(一個自然數)。

解法: 典型的DP問題
設w(h,q)表示從h位開始的q位數字組合所成的十進制數,m(i,j)表示前i位數字串所得的最大j乘積,初始值為:

m(i,0) = w(1,q) ;

動規方程如下所示:

if (j==0) m(i,j) = w(1,q) ;else if(j>0)m(i,j) = max { m(d,j-1)*w(d+1,i-d) } 

ps: 其中 1 <= d < i

代碼:

#include <stdio.h>#include <stdlib.h>#include <string.h>#define MAXN 51#define MAXK 10long m[MAXK][MAXN]={{0,0}} ; /*初始化操作*/long my_10_pow(int t){  long sum=1 ;  int y;  for(y=1 ; y<= t ; y++)  sum *= 10 ;    return sum ;}long w(int start,int len,int *a)/*把數字串轉換成對應的十進制數*/{  long res = 0 ;  int t,f;  for(f=start,t=len-1;t >= 0 ; f++,t--)  res += a[f]*my_10_pow(t) ;    return res ;}    void maxdp(int n,int k,int *a){  int i,j,d,h,q,t,s;  long temp,max;  for(i=1; i<= n ; i++)  m[i][0] = w(1,i,a) ;      for(i=1 ; i<= n ; i++) /*DP 過程。。。。*/  for(j=1; j<= k ; j++)  {    max = 0;    if( i <= j) /*如果長度小于乘號的個數,則值為0*/    m[i][j] = 0 ;    else    {        for(d=1; d < i ; d++)    if ( (temp = m[d][j-1]*w(d+1,i-d,a)) > max)      max = temp ;    m[i][j] = max ;    }      }  }     int main(void){ int n,k,i,j; int a[MAXN]={0},la=0; char c ; scanf("%d %d ",&n,&k);  while ( ( c=getchar() )!=' ') /*讀入數據*/ {   a[++la] = c-'0' ; }  maxdp(n,k,a) ;  printf("max = %ld ",m[n][k]) ;  system("pause");  return 0;}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产丝袜一区二区三区| 最新的欧美黄色| 欧美激情精品久久久久久蜜臀| 国产精品成人一区二区| 中文字幕日韩精品有码视频| 欧美日韩国产区| 91免费电影网站| 97人洗澡人人免费公开视频碰碰碰| 91av视频导航| 国产精品丝袜视频| 日韩中文字幕在线精品| 日本一区二区在线播放| 亚洲色图13p| 韩国视频理论视频久久| 91精品成人久久| 91免费的视频在线播放| 欧美高清视频在线观看| 啪一啪鲁一鲁2019在线视频| 国产精品夜间视频香蕉| 精品久久久久久久大神国产| 国产激情视频一区| 国产日韩在线视频| 欧美在线观看视频| 亚洲成人黄色网| 亚洲色图狂野欧美| 97精品国产97久久久久久| 国产视频精品va久久久久久| 国产在线a不卡| 国产激情视频一区| 一区二区成人av| 欧美激情女人20p| 91在线无精精品一区二区| 亚洲激情视频在线播放| 成人女保姆的销魂服务| 亚洲精品久久久久久久久久久| 精品国产一区二区三区在线观看| 日韩在线国产精品| 国产亚洲综合久久| 国产精品露脸av在线| 欧美黑人性视频| 91精品在线观看视频| 国产视频亚洲精品| 亚洲最大成人免费视频| 久久夜精品va视频免费观看| 亚洲免费影视第一页| 久久夜色撩人精品| 欧美xxxx做受欧美| 黄色精品一区二区| 国产欧美va欧美va香蕉在| 亚洲精品国产精品自产a区红杏吧| 久久久伊人欧美| 亚洲最大成人网色| 国产福利精品视频| 国产伦精品免费视频| 精品中文字幕在线| 久久久久久国产三级电影| 日韩欧美国产网站| 51色欧美片视频在线观看| 日韩欧美国产黄色| www.欧美精品一二三区| 亚洲成人精品在线| 91在线色戒在线| 欧美午夜www高清视频| 国产亚洲欧美一区| 日韩中文字幕视频在线| 亚洲视频网站在线观看| 成人午夜两性视频| 91chinesevideo永久地址| 亚洲自拍中文字幕| 欧美做受高潮1| 精品久久久久人成| 亚洲免费中文字幕| 亚洲跨种族黑人xxx| 久久精品男人天堂| 国产99视频在线观看| 亚洲乱码av中文一区二区| 色偷偷888欧美精品久久久| 奇米成人av国产一区二区三区| 欧美专区中文字幕| 国产美女精彩久久| 国产精品视频一区国模私拍| 欧美视频二区36p| 欧美精品在线看| www.日韩不卡电影av| 国产日韩中文字幕| 国产日韩在线看| 国产一区二区三区在线免费观看| 日韩欧美成人精品| 欧美激情精品久久久久久免费印度| 国产精品第10页| 欧美老少做受xxxx高潮| 欧美激情免费视频| 亚洲第一精品夜夜躁人人爽| 亚洲精品国产综合区久久久久久久| 国产精品免费网站| 日韩精品在线观看网站| 亚洲女人被黑人巨大进入| 欧美精品一区二区三区国产精品| 国产香蕉一区二区三区在线视频| 国产成人精品久久久| 久久久久久久久电影| 6080yy精品一区二区三区| 国产成人一区二区在线| 色婷婷综合久久久久| 一区二区欧美日韩视频| 欧美成人国产va精品日本一级| 成人福利网站在线观看11| 久热精品在线视频| 亚洲福利在线观看| 91久久国产综合久久91精品网站| 日韩欧美中文字幕在线观看| 成人精品一区二区三区电影免费| 亚洲天堂av综合网| 国产欧美日韩免费| 国产女人18毛片水18精品| 成人激情在线播放| 伊人久久久久久久久久久| 欧美第一黄网免费网站| 精品性高朝久久久久久久| 精品国产91久久久| 亚洲激情视频在线播放| 亚洲国产精品电影在线观看| 91精品国产自产91精品| 日韩电影在线观看中文字幕| 国产在线观看91精品一区| 欧美一级淫片aaaaaaa视频| 亚洲欧美精品在线| 日韩av一区二区在线观看| 欧美精品精品精品精品免费| 亚洲午夜女主播在线直播| 亚洲免费影视第一页| 久久国产精品亚洲| 日韩av电影手机在线观看| 亚洲国产精品美女| 欧美成人免费在线观看| 尤物99国产成人精品视频| 国产精品久久久久久久午夜| 97在线看免费观看视频在线观看| 欧美性猛交99久久久久99按摩| 在线激情影院一区| 日韩免费高清在线观看| 亚洲国产成人精品女人久久久| 日韩欧美精品在线观看| 亚洲国产美女久久久久| 亚洲欧美国产日韩天堂区| 黑人精品xxx一区| 亚洲国产精品网站| 26uuu亚洲伊人春色| 欧美激情综合色综合啪啪五月| 国产91精品久久久久| 日韩网站在线观看| 欧美又大又硬又粗bbbbb| 日韩中文字幕国产精品| 亚洲午夜未满十八勿入免费观看全集| 亚洲一区二区久久久久久久| 中文字幕日韩av综合精品| 日韩极品精品视频免费观看| 日本一区二区在线免费播放| 国语自产在线不卡| 九九精品视频在线观看| 欧美日本高清视频| 国产精品成人国产乱一区| 亚洲美腿欧美激情另类| 国产精品视频精品视频|