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

首頁 > 編程 > Ruby > 正文

Ruby實現的最優二叉查找樹算法

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

算法導論上的偽碼改寫而成,加上導論的課后練習第一題的解的構造函數。

復制代碼 代碼如下:

#encoding: utf-8
=begin
author: xu jin
date: Nov 11, 2012
Optimal Binary Search Tree
to find by using EditDistance algorithm
refer to <<introduction to algorithms>>
example output:
"k2 is the root of the tree."
"k1 is the left child of k2."
"d0 is the left child of k1."
"d1 is the right child of k1."
"k5 is the right child of k2."
"k4 is the left child of k5."
"k3 is the left child of k4."
"d2 is the left child of k3."
"d3 is the right child of k3."
"d4 is the right child of k4."
"d5 is the right child of k5."

The expected cost is 2.75. 
=end

INFINTIY = 1 / 0.0
a = ['', 'k1', 'k2', 'k3', 'k4', 'k5']
p = [0, 0.15, 0.10, 0.05, 0.10, 0.20]
q = [0.05, 0.10, 0.05, 0.05, 0.05 ,0.10]
e = Array.new(a.size + 1){Array.new(a.size + 1)}
root = Array.new(a.size + 1){Array.new(a.size + 1)}

def optimalBST(p, q, n, e, root)
  w = Array.new(p.size + 1){Array.new(p.size + 1)}
  for i in (1..n + 1)
    e[i][i - 1] = q[i - 1]
    w[i][i - 1] = q[i - 1]
  end
  for l in (1..n)
    for i in (1..n - l + 1)
      j = i + l -1
      e[i][j] = 1 / 0.0
      w[i][j] = w[i][j - 1] + p[j] + q[j]
      for r in (i..j)
        t = e[i][r - 1] + e[r + 1][j] + w[i][j]
        if t < e[i][j]
          e[i][j] = t
          root[i][j] = r
        end
      end
    end
  end
end

def printBST(root, i ,j, signal)
  return if i > j
  if signal == 0
   p "k#{root[i][j]} is the root of the tree."
   signal = 1
  end
  r = root[i][j]
  #left child
  if r - 1< i
    p "d#{r - 1} is the left child of k#{r}."
  else
    p "k#{root[i][r - 1]} is the left child of k#{r}."
    printBST(root, i, r - 1, 1 )
  end
  #right child
  if r >= j
     p "d#{r} is the right child of k#{r}."
  else
    p "k#{root[r + 1][j]} is the right child of k#{r}."
    printBST(root, r + 1, j, 1)
  end
 
end

optimalBST(p, q, p.size - 1, e, root)
printBST(root, 1, a.size-1, 0)
puts "/nThe expected cost is #{e[1][a.size-1]}."

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品久久久久久亚洲调教| 久久精品国产久精国产思思| 欧美一区第一页| 亚洲毛片在线看| 国产日韩精品在线播放| 亚洲成人网在线| 俺去啦;欧美日韩| 久久亚洲春色中文字幕| 这里只有精品在线播放| 欧美成人精品在线视频| 成人亚洲综合色就1024| 久久免费观看视频| 日韩中文字幕不卡视频| 深夜福利91大全| 日韩av电影国产| 亚洲女人天堂网| 国产精品久久久久久久久免费| 97视频在线观看播放| 欧美在线观看视频| 萌白酱国产一区二区| 国产成人精品视| 国产成人精品免高潮在线观看| 国产欧美精品xxxx另类| 伦伦影院午夜日韩欧美限制| 国产精品入口日韩视频大尺度| 狠狠色狠色综合曰曰| 欧美俄罗斯性视频| 欧美日韩中文在线| 久久精品影视伊人网| 国产精品久久久一区| 在线精品国产成人综合| 欧美中文字幕第一页| 高清欧美性猛交xxxx| 日本中文字幕久久看| 亚洲在线第一页| 欧美人成在线视频| 日韩大片在线观看视频| 亚洲黄色片网站| 欧美日韩另类字幕中文| 亚洲视频自拍偷拍| 国产精品欧美日韩| 在线成人免费网站| 亚洲欧洲国产精品| 亚洲一级黄色av| 亚洲女人天堂网| 福利一区福利二区微拍刺激| 亚洲一区二区三区视频| 日韩电视剧免费观看网站| 久久伊人91精品综合网站| 伊人久久五月天| 日韩成人中文电影| 疯狂蹂躏欧美一区二区精品| 91精品啪在线观看麻豆免费| 欧美人在线观看| 91久久久久久久久| 日韩精品久久久久久久玫瑰园| 69视频在线免费观看| 97在线看免费观看视频在线观看| 亚洲精品日韩久久久| 一本一本久久a久久精品综合小说| 97视频免费看| 国产主播欧美精品| 亚洲夜晚福利在线观看| 国产ts人妖一区二区三区| 亚洲精品自产拍| 青青久久av北条麻妃黑人| 久久久久久国产三级电影| 欧美性xxxxx极品娇小| 久久av红桃一区二区小说| 精品福利免费观看| 45www国产精品网站| 国产精品久久久久7777婷婷| 欧美激情奇米色| 国产精品91免费在线| 全球成人中文在线| 在线看欧美日韩| 久久久这里只有精品视频| 在线观看国产欧美| 亚洲老头老太hd| 日本高清不卡在线| 亚洲第一偷拍网| 亚洲国产一区二区三区在线观看| 国产91ⅴ在线精品免费观看| 亚洲人成绝费网站色www| 97在线看免费观看视频在线观看| 午夜精品一区二区三区av| 亚洲国产美女久久久久| 亚洲精品有码在线| 亚洲欧美日韩一区在线| 亚洲精品欧美日韩| 国外成人在线直播| 国产精品中文字幕在线| 国产精品免费在线免费| 日韩久久精品电影| 91国内精品久久| 这里只有视频精品| 国产人妖伪娘一区91| 欧美精品在线第一页| 在线成人激情视频| 欧美精品久久久久a| 国产亚洲欧美日韩美女| 国模极品一区二区三区| 欧美激情性做爰免费视频| 国产情人节一区| 91av免费观看91av精品在线| 精品久久久精品| 黄色精品在线看| 久久福利视频导航| 亚洲国产另类 国产精品国产免费| 欧美人与物videos| 国产精品av在线播放| 成人久久精品视频| 久久久精品中文字幕| 亚洲高清色综合| 欧美孕妇孕交黑巨大网站| 国产精品va在线播放我和闺蜜| 欧美视频在线观看免费网址| 精品久久久久久中文字幕一区奶水| 久久久国产一区二区三区| 91福利视频在线观看| 91九色蝌蚪国产| 精品久久久久久久久中文字幕| 国产成+人+综合+亚洲欧美丁香花| 成人黄色午夜影院| 国产精品盗摄久久久| 国产精品欧美激情在线播放| 日韩电视剧免费观看网站| 亚洲久久久久久久久久久| 亚洲自拍中文字幕| 精品调教chinesegay| 高清一区二区三区四区五区| 国产精品扒开腿做爽爽爽男男| 91亚洲永久免费精品| 亚洲福利在线视频| 日韩久久精品成人| 在线观看精品国产视频| 丝袜亚洲欧美日韩综合| 国产精品成人aaaaa网站| 国产精品爽黄69天堂a| 日本一区二区三区四区视频| 亚洲欧美另类自拍| 午夜精品久久17c| 日韩av三级在线观看| 福利一区视频在线观看| 51精品国产黑色丝袜高跟鞋| 国产69精品久久久久9| 久久亚洲电影天堂| 国产91精品高潮白浆喷水| 欧美日韩亚洲系列| 国产成人一区二区在线| 欧美—级a级欧美特级ar全黄| 精品视频偷偷看在线观看| 米奇精品一区二区三区在线观看| 色偷偷av亚洲男人的天堂| 国产精品久久久久国产a级| 久久久久久有精品国产| 精品国产视频在线| 久久久久久久成人| 国产mv免费观看入口亚洲| 亚洲自拍偷拍网址| 色偷偷偷综合中文字幕;dd| 日本精品久久久久影院| 国产精品激情av在线播放| 成人精品一区二区三区|