首页 > 解决方案 > 编译哈希算法时出现内存访问冲突错误

问题描述

将字符串插入内存时出现错误。0xC0000005 访问冲突错误。我试图更改导致分配错误的数组大小。int 主要部分仅将字符串单词发送到插入函数,直到文件结束。

#include<string>
#include<iostream>
#include <fstream>
using namespace std;
const unsigned int MAX = INT16_MAX;
string *words = new string[MAX];
int* instances = new int[MAX];

//int* alloc = new int[MAX];
int ucounts = 0;

static unsigned int FNVHash(string str) {
const unsigned int fnv_prime = 0x811C9DC5;
unsigned int hash = 0;
unsigned int i = 0;
unsigned int len = str.length();

for (i = 0; i < len; i++)
{
    hash *= fnv_prime;
    hash ^= (str[i]);
}

return hash;
}

void insert(string input) {
//check first, add if not present

if (words[FNVHash(input)] != input) {  //<-Compiler shows error here.
    words[FNVHash(input)] = input;
    instances[FNVHash(input)]=1;
    ucounts++;
}
else {

    instances[FNVHash(input)]++;
}   
}

标签: c++arraysstring-hashing

解决方案


您没有任何东西可以将返回的值限制FNVHashwords. 要么FNVHash需要确保散列在 [0..NAX] 范围内,要么用户 ( insert) 需要这样做。


推荐阅读