哈希算法解析

哈希算法概述

哈希算法(Hash Algorithm)是一种将任意长度的输入数据映射为固定长度输出(哈希值)的函数。哈希值通常用于数据完整性校验、密码存储、快速查找等领域。核心特性包括确定性、高效性、抗碰撞性(难以找到两个不同输入产生相同输出)和雪崩效应(微小输入变化导致输出巨大差异)。

常见哈希算法

复制代码
MD5:生成128位哈希值,曾广泛用于校验文件完整性,但因碰撞漏洞已不推荐用于安全场景。
SHA-1:生成160位哈希值,同样存在碰撞风险,逐步被淘汰。
SHA-2系列:包括SHA-256、SHA-512等,安全性更高,广泛应用于SSL/TLS、区块链等。
SHA-3:基于Keccak算法,设计上与SHA-2不同,提供另一种安全选择。

哈希算法应用场景

复制代码
数据校验:通过对比哈希值验证文件传输是否完整(如下载文件的MD5校验)。
密码存储:存储密码的哈希值而非明文,结合盐值(Salt)防止彩虹表攻击。
数据结构:哈希表(HashMap)利用哈希函数实现O(1)时间复杂度的快速查找。
区块链:比特币使用SHA-256计算区块哈希,确保数据不可篡改。

代码示例

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
#define ULL unsigned long long
const int N = 1e5+5, base = 1007;
string s,T;
int n, cnt;
string ans[N];

void solve() {
	cin >> n >> s;
	ULL hs = 0, tol = 1, len = s.length();
	for(int i=0;i<len;i++) {
		hs = hs * base + s[i];					// H(s) = (s[0] * x^(len-1) + s[1] * x^(len-2) + ...+ s[len-1]) mod MOD 
		tol *= base;							// tol = x ^ len 
	}
	for(int _=0;_<n;_++) {
		cin	>> T;
		ULL ht = 0;
		for(int i=0;i<T.length();i++) {
			ht = ht * base + T[i];				// 加上第 i 个字符的哈希值 
			if(i>=s.length()) 					// 当前超出 模式串 s 的长度 
				ht -= tol * T[i-len];			// 减去 base ^ len * T[r-len]  
			if(ht==hs) {						// 匹配 
				ans[cnt++] = T;					// 计入答案 
				break;
			}
		} 		
	}
	sort(ans,ans+cnt);
	for(int i=0;i<cnt;i++) 
		cout << ans[i] << '\n';
}

int main() {
	ios::sync_with_stdio(NULL),
	cin.tie(nullptr),cout.tie(nullptr);
	solve();
	return 0; 
}
相关推荐
YuTaoShao3 分钟前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法一)前后缀分解
算法·leetcode·职场和发展
VT.馒头10 分钟前
【力扣】2727. 判断对象是否为空
javascript·数据结构·算法·leetcode·职场和发展
goodluckyaa19 分钟前
LCR 006. 两数之和 II - 输入有序数组
算法
孤狼warrior20 分钟前
YOLO目标检测 一千字解析yolo最初的摸样 模型下载,数据集构建及模型训练代码
人工智能·python·深度学习·算法·yolo·目标检测·目标跟踪
Σίσυφος190044 分钟前
PCL法向量估计 之 RANSAC 平面估计法向量
算法·机器学习·平面
xhbaitxl1 小时前
算法学习day39-动态规划
学习·算法·动态规划
I_LPL1 小时前
day23 代码随想录算法训练营 回溯专题2
算法·hot100·回溯算法·求职面试
智者知已应修善业1 小时前
【洛谷P9975奶牛被病毒传染最少数量推导,导出多样例】2025-2-26
c语言·c++·经验分享·笔记·算法·推荐算法
m0_736919101 小时前
C++中的委托构造函数
开发语言·c++·算法
小小小小王王王1 小时前
洛谷-P1886 【模板】单调队列 / 滑动窗口
c++·算法