题目描述:我们从碎纸机里抢救回来了某个关键图片资料,你能帮我们修复它吗?
题目环境:https://download.csdn.net/download/m0_59188912/87094757

images = []
def judge(A, B):
diff = 0
for r in range(0, len(A)):
#diff += (A[r][len(A[0]) - 1][0] - B[r][0])[0]
#diff += (A[r][len(A[0]) - 1][1] - B[r][0])[1]
diff += (A[r][len(A[0]) - 1][2] - B[r][0])[2] ** 0.25
return diff
def combine(A, B):
final_matrix = numpy.zeros((len(A), len(A[0]) + len(B[0]), 3), numpy.uint8)
final_matrix[0:len(A), 0:len(A[0])] = A
final_matrix[0:len(A), len(A[0]):len(A[0]) + len(B[0])] = B
return final_matrix
if name == “main”:
f_images = os.listdir(“./images”) #获取images目录下所有文件或文件夹(不包括.和…)
for f_image in f_images:
images.append(
cv2.imread(
“images\” + f_image
)
) #列表存放OpenCV读取的图片
while len(images) > 1:
min_entropy = -1
to_combine = None
for i in range(1, len(images)):
entropy = judge(images[0], images[i])
if min_entropy == -1 or entropy < min_entropy:
min_entropy = entropy
to_combine = i
images[0] = combine(images[0], images[to_combine])
print(len(images), len(images[0][0]))
images.pop(to_combine)
cv2.imwrite(“./result.png”, images[0])




本篇博客为本人解题write up,如有错误之处,还望各位指正。
文章为原创,如要转载请注明出处