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

首頁 > 編程 > Python > 正文

python求解數組中兩個字符串的最小距離

2020-02-15 23:04:03
字體:
來源:轉載
供稿:網友

題目:

給定一個數組 strs,其中的數據都是字符串,給定兩個字符串 str1,str2。如果這兩個字符串都在 strs數組中,就返回它們之間的最小距離;如果其中任何一個不在里面,則返回 -1;如果兩個字符串相等,則返回 0。

例如:給定[‘*','3','*','5','10','9','7','1','*'],再給定兩個字符串'* ‘和'9',通過函數求得返回值 3。

分析:有兩種方法

方法1:

遍歷數組 strs,分別記錄兩個 str1 和 str2 的位置。求得最小的一個距離數字。這樣做時間復雜度為 o(n^2)。

方法2: 

如果查詢的次數非常多,為了提高查詢的效率,構造Hash表,把每次查詢的時間復雜度下降到 o(1)。 
Python 的內置 dict 類型就是哈希表,實現方法也是hash 表,其查詢的時間復雜度就是 o(1)。哈希表的構造也分很多種: 
比如,構造 Hash 表,key值是strs中的每一個字符串,value值是一個hash表,里面存放著該字符串到其它字符串的最小距離。 
寫成代碼就是:hash_table = {“*”:{“3”:1, “5”:1, “10”:2, “9”:3, “7”:2, “1”:1}} 
當然這種方法的空間復雜度是 o(n^2)

代碼: 

 def min_distance_1(strs, str1, str2):  '''  數組中兩個字符串的最小距離,這是方法1,時間復雜度 o(n^2)  :param strs: 給定的數組中存放有多個字符串  :param str1: 第一個字符串  :param str2: 第二個字符串  :return: 如果其中給定的一個字符串不在數組 strs 中,那么返回-1,否則返回兩個字符串之間的最小間距  '''  if str1 not in strs or str2 not in strs:   return -1  if str1 == str2:   return 0  dist, min = 1, len(strs)  pos1, pos2 = 0, len(strs)  for i in xrange(0, len(strs)):   if str1 == strs[i]:    pos1 = i    for j in xrange(0, len(strs)):     if str2 == strs[j]:      pos2 = j     dist = abs(pos1 - pos2)     if dist < min:      min = dist  return min def min_distance_2(strs, str1, str2):  '''  數組中兩個字符串的最小距離,這是方法2,如果查詢的次數非常多,把每次查詢的時間復雜度下降到 o(1)。  Python 的內置 dict 類型就是哈希表,實現方法也是hash 表,其查詢的時間復雜度就是 o(1)。哈希表的構造也分很多種:  比如,構造 Hash 表,key值是strs中的每一個字符串,value值是一個hash表,里面存放著該字符串到其它字符串的最小距離。   寫成代碼就是:hash_table = {"*":{"3":1, "5":1, "10":2, "9":3, "7":2, "1":1}}  當然這種方法的空間復雜度是 o(n^2)  :param strs: 給定的數組中存放有多個字符串['*','3','*','5','10','9','7','1','*']  :param str1: 第一個字符串, '*'  :param str2: 第二個字符串, '9'  :return: 如果其中給定的一個字符串不在數組 strs 中,那么返回-1,否則返回兩個字符串之間的最小間距  '''  if str1 not in strs or str2 not in strs:   return -1  if str1 == str2:   return 0  def create_hash(strs): # 創建 hash 的過程并不在查詢里   strs_set = list(set(strs))   dist_hash = {}   for i in xrange(0, len(strs_set)):    temp = {}    for j in xrange(0, len(strs_set)):     if strs_set[i] != strs_set[j]:      dist = min_distance_1(strs, strs_set[i], strs_set[j])      temp[strs_set[j]] = dist    dist_hash[strs_set[i]] = temp   return dist_hash  return create_hash(strs)[str1][str2]            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美尤物巨大精品爽| 国产99久久精品一区二区永久免费| 亚洲欧美中文日韩在线| 日韩动漫免费观看电视剧高清| 青青草成人在线| 亚洲bt欧美bt日本bt| 中文字幕av一区| 国产丝袜一区二区三区| 国产一区二区三区网站| 欧美性做爰毛片| 一区二区欧美日韩视频| xvideos国产精品| 正在播放欧美视频| 日韩美女在线观看一区| 欧美日韩爱爱视频| 97**国产露脸精品国产| 国产精品女人久久久久久| 国产亚洲xxx| 国产a∨精品一区二区三区不卡| 国产成人啪精品视频免费网| 国产99在线|中文| 一区二区欧美久久| 久久全球大尺度高清视频| 在线丨暗呦小u女国产精品| 97久久国产精品| 精品香蕉一区二区三区| 欧美猛少妇色xxxxx| 日韩小视频在线观看| 国产久一一精品| 国产精品亚洲第一区| 成人国产精品日本在线| 在线看福利67194| 久久久国产一区| 国产精品第1页| 欧美第一黄色网| 在线成人一区二区| 国产精品pans私拍| 欧美高清第一页| 国产成人精品免高潮在线观看| 亚洲国产精品va在线看黑人| 欧美视频专区一二在线观看| 亚洲午夜久久久久久久| 亚洲第一级黄色片| 欧美日韩国产一中文字不卡| 日韩免费看的电影电视剧大全| 欧美激情三级免费| 日韩电影网在线| 欧美黄色www| 中文字幕亚洲专区| 一夜七次郎国产精品亚洲| 欧美日韩电影在线观看| 亚洲色图校园春色| 一区二区三区四区视频| 欧美大全免费观看电视剧大泉洋| 日韩在线欧美在线| 日韩欧美中文字幕在线播放| 91高潮在线观看| 国产日韩精品在线播放| 亚洲人av在线影院| 97在线观看视频国产| 亚洲综合自拍一区| 浅井舞香一区二区| 亚洲淫片在线视频| 日本精品视频在线| 欧美成人午夜视频| 国产精品一区二区三区免费视频| 色妞在线综合亚洲欧美| 91理论片午午论夜理片久久| 91极品女神在线| 亚洲第一网站男人都懂| 高清亚洲成在人网站天堂| 精品久久久国产| 国产日韩中文在线| 国产三级精品网站| 久久福利视频导航| 亚洲欧美激情在线视频| 久久精品一偷一偷国产| 成人xxxx视频| 日韩在线视频一区| 欧美丝袜一区二区| 精品美女久久久久久免费| 美女性感视频久久久| 亚洲欧美日韩中文在线制服| 97在线免费观看| 欧美高清视频在线观看| 91久久精品国产| 国产大片精品免费永久看nba| 青青青国产精品一区二区| 亚洲欧美日韩直播| 欧美亚洲成人xxx| 77777少妇光屁股久久一区| 久久久这里只有精品视频| 欧美国产亚洲视频| 日韩视频免费中文字幕| 亚洲视频自拍偷拍| 色偷偷888欧美精品久久久| 97国产在线视频| 亚洲欧美在线免费观看| 国产成人一区二区三区小说| 亚洲va国产va天堂va久久| 欧美性生活大片免费观看网址| 日韩av影片在线观看| 日韩免费不卡av| 国产91精品久| 国精产品一区一区三区有限在线| 韩国v欧美v日本v亚洲| 欧亚精品中文字幕| 欧美日韩人人澡狠狠躁视频| 欧美理论片在线观看| 成人欧美在线视频| 这里只有精品丝袜| 97碰碰碰免费色视频| 日本成人黄色片| 欧美精品激情在线| 欧美国产高跟鞋裸体秀xxxhd| 亚洲免费福利视频| 色妞在线综合亚洲欧美| 九色精品美女在线| 亚洲一区亚洲二区| 亚洲欧洲第一视频| 国产激情视频一区| 久久这里有精品视频| 自拍偷拍亚洲欧美| 亚洲人成五月天| xxxxxxxxx欧美| 欧洲亚洲女同hd| 欧美视频在线免费| 欧美精品免费播放| 亚洲国产精品成人一区二区| 97视频在线播放| 欧美怡春院一区二区三区| 成人免费视频xnxx.com| 成人免费视频网址| 欧美性色视频在线| 久久中文久久字幕| 国产97在线|亚洲| 日韩av在线网址| 91网站在线看| 欧美高清一级大片| 欧美午夜电影在线| 欧美二区在线播放| 久久精品国产亚洲一区二区| 成人国产精品色哟哟| 2020久久国产精品| 日韩欧美亚洲综合| 久久国产精品亚洲| 久久综合久中文字幕青草| 欧美日韩高清在线观看| 欧美大片在线看免费观看| 国产精品久久一区主播| 这里只有精品在线播放| 91青草视频久久| 国产精品爽黄69天堂a| 亚洲免费视频一区二区| 国产精品久久97| 国产精品中文在线| 日韩欧美在线网址| 国产精品久久婷婷六月丁香| 亚洲图片在区色| 亚洲深夜福利在线| 欧美成人午夜激情在线| 欧美性xxxx极品hd欧美风情| 亚洲缚视频在线观看| 日韩国产在线看|