哈希算法说明及示例

Hash算法:

定义:哈希算法又叫散列算法,是将任意长度的二进制值映射为较短的固定长度的二进制值,这个小的二进制值称为哈希值。它的原理其实很简单,就是把一段交易信息转换成一个固定长度的字符串

特点:

1. 信息相同,字符串也相同。

2. 信息相似不会影响字符串相同。

3. 可以生成无数的信息,但是字符串的种类是一定的,所以是不可逆的。

用途:

1、哈希算法可以检验信息是否是相同的,这样的优势可以节省重复文件传送的时间

2、哈希算法还可以检验信息的拥有者是否真实

示例:

# coding:utf-8 # 使用hashlib模块 import hashlib md5 = hashlib.md5() # 应用MD5算法 data = "hello world" md5.update(data.encode('utf-8'))看 print(md5.hexdigest())

 

自定义哈希:

# coding:utf-8 # 自定义哈希函数 def my_hash(x): return (x % 7) ^ 2 print(my_hash(1)) # 输出结果:3 print(my_hash(2)) # 输出结果:0 print(my_hash(3)) # 输出结果:1 print(my_hash(4)) # 输出结果:6

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值