中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python鏈表法的優缺點有哪些

發布時間:2021-09-07 10:57:45 來源:億速云 閱讀:166 作者:小新 欄目:編程語言

這篇文章主要介紹了python鏈表法的優缺點有哪些,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

1、優點,方便刪除記錄,直接處理數組對應下標的子數組。平均搜索速度快。如果有沖突,只需要查詢子數組。

2、缺點,使用指針導致查詢速度較慢,內存占用可能較高,不適合序列化。

而開放式尋址法的優缺點與鏈表法相反。因為Python的一切都是基于Dict的,都需要序列化,所以選擇了開放式尋址法。

實例

   # keys函數
#!/usr/bin/env python
# coding=utf-8
 
class Dict:
    def __init__(self, num):
        self.__solts__ = []
        self.num = num
        for _ in range(num):
            self.__solts__.append([])
    def hash_fun(self,key,num):
        hashval = 0
        x = key
        if x < 0:
                print "the key is low"
                return
        while x != 0:
                hashval = (hashval << 3) + x%10
                x /=10
        return hashval % num
    def put(self, key, value):
        i = self.hash_fun(key,self.num) % self.num
        for p, (k, v) in enumerate(self.__solts__[i]):
            if k == key:
                break
        else:
            self.__solts__[i].append((key, value))
            return
        self.__solts__[i][p] = (key, value)
    def get(self, key):
        i = self.hash_fun(key,self.num) % self.num
        for k, v in self.__solts__[i]:
            if k == key:
                return v
        raise KeyError(key)
    # keys函數
    def keys(self):
        ret = []
        for solt in self.__solts__:
            for k, _ in solt:
                ret.append(k)
        return ret
    def __getitem__(self,key):
        return self.get(key)
 
    def __setitem__(self,key,data):
        self.put(key,data)
H = Dict(13)
H[54] = "cat"
H[26] = "dog"
H[93] = "lion"
H[17] = "tiger"
H[77] = "bird"
H[31] = "cow"
H[44] = "goat"
H[55] = "pig"
H[20] = "chicken"
print H.get(54)
H.put(13,"duck")
print H.__solts__
print H.keys()

感謝你能夠認真閱讀完這篇文章,希望小編分享的“python鏈表法的優缺點有哪些”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

临泉县| 万盛区| 双鸭山市| 安远县| 华宁县| 永新县| 苍南县| 寿光市| 龙胜| 岱山县| 舒兰市| 格尔木市| 上高县| 镶黄旗| 虎林市| 阆中市| 新龙县| 涿鹿县| 杭州市| 和政县| 哈尔滨市| 崇信县| 青海省| 噶尔县| 四川省| 兴安县| 高要市| 长垣县| 泽州县| 达日县| 墨竹工卡县| 甘洛县| 阿拉善右旗| 保定市| 霍山县| 同心县| 莱州市| 息烽县| 沾益县| 赤城县| 东辽县|