一、概念:素数又称质数,是大于1的自然数,除了1和自身外,没有其他正因子的数。换句话说,素数只能被1和自身整除。
二、判断一个数num是否是素数的模板:
bool isPrime(int num) {
if (num <= 1)
return false; // 0 和 1 不是素数
// 检查从 2 到 sqrt(num) 的所有数是否能整除 num
for (int i = 2; i * i <= num; i++) {
if (num % i == 0)
return false; // 如果能被整除,则不是素数
}
return true; //否则,num是素数
}
三、素数的典型运用:
1.生成指定范围内的素数列表(关键代码):
void printPrimes(int start, int end) {
for (int i = start; i <= end; i++) {
if (isPrime(i)) {
cout<< i;
}
}
cout<<endl;
}
2.使用素数进行哈希运算(简单示例):
// 假设我们有一个简单的哈希函数,它只考虑字符串的长度并使用素数作为乘数
unsigned int simpleHash(const char *str, unsigned int prime) {
unsigned int hash = 0;
while (*str) {
hash = (hash * prime) + (*str++);
}
return hash;
}
在这个示例中,我们定义了一个简单的哈希函数,它遍历字符串中的每个字符,并使用一个素数作为乘数来计算哈希值。这种方法虽然简单,但说明了在哈希计算中使用素数的一个基本思想:通过选择一个质数作为乘数,可以增加哈希函数的分散性,从而减少哈希冲突的可能性。