日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

重温经典算法系列: 动态规划法

發(fā)布時間:2024/4/14 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 重温经典算法系列: 动态规划法 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

題記:

??????? 曾經(jīng)享受于算法的或新穎或優(yōu)美或簡潔,也曾經(jīng)因領(lǐng)會熟知算法在一些考試、競賽(如軟考和軟件開發(fā)比賽)和工作中屢試不爽,但是,近來一段時間,對于算法這種靈魂類的東東似乎少有染指,實為遺憾,非常危險:)。算法,是軟件開發(fā)中的瑰寶,是思維領(lǐng)域的奇葩,作為IT人員,應(yīng)該“必需的”,應(yīng)該作為一種素養(yǎng),常習(xí)常新。使成為專業(yè)上效率與創(chuàng)造的沃土,升華成人生中智慧與樂趣的源泉。

?????????????????? [勘誤:本文c語言版程序有誤,因輸入排版原因如需正確源碼請與本人交流獲得或從http://www.coco2008.net [ 資料下載]欄目獲取]

動態(tài)規(guī)劃法

經(jīng)常會遇到復(fù)雜問題不能簡單地分解成幾個子問題,而會分解出一系列的子問題。簡單地采用把大問題分解成子問題,并綜合子問題的解導(dǎo)出大問題的解的方法,問題求解耗時會按問題規(guī)模呈冪級數(shù)增加。

為了節(jié)約重復(fù)求相同子問題的時間,引入一個數(shù)組,不管它們是否對最終解有用,把所有子問題的解存于該數(shù)組中,這就是動態(tài)規(guī)劃法所采用的基本方法。以下先用實例說明動態(tài)規(guī)劃方法的使用。

【問題】 求兩字符序列的最長公共字符子序列

問題描述:字符序列的子序列是指從給定字符序列中隨意地(不一定連續(xù))去掉若干個字符(可能一個也不去掉)后所形成的字符序列。令給定的字符序列X=“x0,x1,…,xm-1,序列Y=“y0,y1,…,yk-1X的子序列,存在X的一個嚴(yán)格遞增下標(biāo)序列<i0,i1,…,ik-1>,使得對所有的j=0,1,…,k-1,有xij=yj。例如,X=“ABCBDAB”,Y=“BCDB”是X的一個子序列。

考慮最長公共子序列問題如何分解成子問題,設(shè)A=“a0,a1,…,am-1B=“b0,b1,…,bm-1,并Z=“z0,z1,…,zk-1為它們的最長公共子序列。不難證明有以下性質(zhì):

(1如果am-1=bn-1,則zk-1=am-1=bn-1,且“z0,z1,…,zk-2是“a0,a1,…,am-2和“b0,b1,…,bn-2的一個最長公共子序列;

(2如果am-1!=bn-1,則若zk-1!=am-1,蘊涵“z0,z1,…,zk-1是“a0,a1,…,am-2和“b0,b1,…,bn-1的一個最長公共子序列;

(3如果am-1!=bn-1,則若zk-1!=bn-1,蘊涵“z0,z1,…,zk-1是“a0,a1,…,am-1和“b0,b1,…,bn-2的一個最長公共子序列。

這樣,在找A和B的公共子序列時,如有am-1=bn-1,則進一步解決一個子問題,找“a0,a1,…,am-2和“b0,b1,…,bm-2的一個最長公共子序列;如果am-1!=bn-1,則要解決兩個子問題,找出“a0,a1,…,am-2和“b0,b1,…,bn-1的一個最長公共子序列和找出“a0,a1,…,am-1和“b0,b1,…,bn-2的一個最長公共子序列,再取兩者中較長者作為A和B的最長公共子序列。

代碼如下:

# include <stdio.h>

# include <string.h>

# define N 100

char a[N],b[N],str[N];

?

int lcs_len(char *a, char *b, int c[ ][ N])

{ int m=strlen(a), n=strlen(b), i,j;

for (i=0;i<=m;i++) c[i][0]=0;

for (i=0;i<=n;i++) c[0][i]=0;

for (i=1;i<=m;i++)

for (j=1;j<=m;j++)

if (a[i-1]==b[j-1])

c[i][j]=c[i-1][j-1]+1;

else if (c[i-1][j]>=c[i][j-1])

c[i][j]=c[i-1][j];

else

c[i][j]=c[i][j-1];

return c[m][n];

}

?

char *buile_lcs(char s[ ],char *a, char *b)

{ int k, i=strlen(a), j=strlen(b);

k=lcs_len(a,b,c);

s[k]=’"0’;

while (k>0)

if (c[i][j]==c[i-1][j]) i--;

else if (c[i][j]==c[i][j-1]) j--;

else { s[--k]=a[i-1];

i--; j--;

}

return s;

}

?

void main()

{ printf (“Enter two string(<%d)!"n”,N);

scanf(“%s%s”,a,b);

printf(“LCS=%s"n”,build_lcs(str,a,b));

}

總結(jié)

以上是生活随笔為你收集整理的重温经典算法系列: 动态规划法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。