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

首頁 > 編程 > Python > 正文

python實現馬耳可夫鏈算法實例分析

2019-11-25 17:26:02
字體:
來源:轉載
供稿:網友

本文實例講述了python實現馬耳可夫鏈算法的方法。分享給大家供大家參考。具體分析如下:

在《程序設計實踐》(英文名《The Practice of Programming》)的書中,第三章分別用C語言,C++,AWK和Perl分別實現了馬耳可夫鏈算法,來通過輸入的文本,“隨機”的生成一些有用的文本。

說明:

1. 程序使用了字典,字典和散列可不是一個東西,字典是鍵值對的集合,而散列是一種能夠常數階插入,刪除,不過可以用散列來實現字典。
2. 字典的setdefault()方法使得程序少了許多條件判斷。
3. random.choice()可以隨機取出一個序列中的元素。
4. 每兩個前綴詞確定一個后綴。

實現代碼:

import randomimport sysMAXGEN = 10000NONWORD = '/n'w1 = w2 = NONWORDstatetab = {}text = sys.stdin.read()words = text.split()for word in words:  statetab.setdefault((w1, w2),[]).append(word)  w1, w2 = w2, word# add tailstatetab.setdefault((w1, w2),[]).append(NONWORD)# show mar wordsw1 = w2 = NONWORDfor i in xrange(MAXGEN):  suf = statetab[(w1,w2)]  t = random.choice(suf)  if t == NONWORD: break  print t  w1, w2 = w2, t

希望本文所述對大家的Python程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 遂溪县| 无棣县| 罗甸县| 凤台县| 台山市| 敖汉旗| 临澧县| 田阳县| 许昌县| 扎囊县| 连平县| 宝丰县| 罗山县| 义马市| 达拉特旗| 内江市| 新源县| 淳安县| 遵义市| 静宁县| 胶州市| 濮阳市| 南部县| 平和县| 伊通| 台南市| 渝中区| 霍城县| 茂名市| 敖汉旗| 荆门市| 和平县| 北海市| 斗六市| 朔州市| 阳春市| 岫岩| 苍山县| 太仆寺旗| 北流市| 祁东县|