Python LZW 演算法
Python LZW 演算法
LZW 壓縮演算法
string = "thisisthe"
dictionary = {chr(i):i for i in range(97,123)}
last = 256
p = ""
result = []
for c in string:
pc = p+c
if pc in dictionary:
p = pc
else:
result.append(dictionary[p])
dictionary[pc] = last
last += 1
p = c
if p != "":
result.append(dictionary[p])
print(result)
以上代碼運行結果為:
[116, 104, 105, 115, 258, 256, 101]
LZW 解壓縮演算法
dictionary = {i:chr(i) for i in range(97,123)}
last = 256
arr = [97, 97, 98, 256, 258, 257, 259]
result = []
p = arr.pop(0)
result.append(dictionary[p])
for c in arr:
if c in dictionary:
entry = dictionary[c]
result.append(entry)
dictionary[last] = dictionary[p] + entry[0]
last += 1
p = c
print("".join(result))
以上代碼運行結果為:
aabaabaabaab
※Windows下BVLC Caffe的安裝與配置
※python解包和壓包
TAG:程序員小新人學習 |