哈希算法解析

哈希算法概述

哈希算法(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; 
}
相关推荐
free-elcmacom几秒前
机器学习高阶教程<11>当数据开始“折叠”:流形学习与深度神经网络如何发现世界的隐藏维度
人工智能·python·神经网络·学习·算法·机器学习·dnn
小年糕是糕手5 分钟前
【C/C++刷题集】string类(一)
开发语言·数据结构·c++·算法·leetcode
努力学算法的蒟蒻10 分钟前
day40(12.21)——leetcode面试经典150
算法·leetcode·面试
ToddyBear12 分钟前
从字符游戏到 CPU 指令集:一道算法题背后的深度思维跃迁
数据结构·算法
光影少年14 分钟前
前端算法新手如何刷算法?
前端·算法
Andyshengwx25 分钟前
图论 最小生成树 MST问题
c++·算法·图论
賬號封禁中miu26 分钟前
图论之最小生成树
java·数据结构·算法·图论
闻缺陷则喜何志丹26 分钟前
【图论 拓扑排序 贪心 临项交换】P5603 小 C 与桌游 题解|普及+
c++·算法·图论·贪心·拓扑排序·洛谷·临项交换
闻缺陷则喜何志丹27 分钟前
【图论 BFS染色 并集查找 】P3663 [USACO17FEB] Why Did the Cow Cross the Road III S|普及+
c++·算法·图论·染色法·宽度优先·并集查找
青山如墨雨如画28 分钟前
【北邮-研-图论】网络最大流的标号算法V1.0
网络·算法·图论·北邮