a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > Ruby > 正文

Ruby實現的最長公共子序列算法

2020-10-29 19:39:11
字體:
來源:轉載
供稿:網友

最長公共子序列,LCS,動態規劃實現。

#encoding: utf-8#author: xu jin, 4100213#date: Nov 01, 2012#Longest-Commom-Subsequence#to find a longest commom subsequence of two given character arrays by using LCS algorithm#example output:#The random character arrays are: ["b", "a", "c", "a", "a", "b", "d"] and ["a", "c", "a", "c", "a", "a", "b"]#The Longest-Commom-Subsequence is: a c a a bchars = ("a".."e").to_ax, y = [], []1.upto(rand(5) + 5) { |i| x << chars[rand(chars.size-1)] }1.upto(rand(5) + 5) { |i| y << chars[rand(chars.size-1)] }printf("The random character arrays are: %s and %s/n", x, y)c = Array.new(x.size + 1){Array.new(y.size + 1)}b = Array.new(x.size + 1){Array.new(y.size + 1)}def LCS_length(x, y ,c ,b)    m, n = x.size, y.size   (0..m).each{|i| c[i][0] = 0}   (0..n).each{|j| c[0][j] = 0}   for i in (1..m) do    for j in(1..n) do    if(x[i - 1] == y [j - 1])     c[i][j] = c[i - 1][j - 1] + 1;     b[i][j] = 0    else     if(c[i - 1][j] >= c[i][j - 1])      c[i][j] = c[i - 1][j]      b[i][j] = 1     else      c[i][j] = c[i][j - 1]      b[i][j] = 2     end    end   end   endenddef Print_LCS(x, b, i, j)  return if(i == 0 || j == 0)  if(b[i][j] == 0)    Print_LCS(x, b, i-1, j-1)    printf("%c ", x[i - 1])  elsif(b[i][j] == 1)    Print_LCS(x, b, i-1, j)  else    Print_LCS(x, b, i, j-1)  endendLCS_length(x, y, c ,b) print "The Longest-Commom-Subsequence is: "Print_LCS(x, b, x.size, y.size)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产精品美女久久久久aⅴ国产馆 | 欧美性受| 亚洲四区 | 国产精品久久久久桃色tv | 国产精品一线二线三线 | 国产精品美女一区二区三区四区 | 色婷婷在线视频 | 日韩国产欧美一区二区 | 黄色电影网站在线观看 | 秋霞国产| 欧美高清在线 | 97人人干 | 亚洲精品一区二区网址 | 国产免费看av大片的网站吃奶 | 91久久久久 | 国产精品1区2区 | 91精品国产麻豆 | 在线观看第一页 | 日韩大片一区 | 精品久久久久久亚洲综合网站 | 久久一级 | 亚洲丶国产丶欧美一区二区三区 | 人人草人人看 | 欧美自拍视频 | 久久久久网站 | 久久久女人 | 日韩免费视频一区二区 | 亚洲视频精品一区 | 成人精品视频 | h视频免费 | 影音先锋国产 | 国产99页| 国产日韩一区二区 | 精品国产乱码久久久久久久软件 | 亚洲国产精品成人无久久精品 | 欧美精品一区二区三区四区 | 欧美视频第一页 | 青青草一区 | 国产精品一区人伦免视频播放 | 欧美日韩国产中文 | 日韩久久久久久 |