我正在尝试将字符串转换为无符号字符*。我一直在绕圈子。 我的程序提示用户输入一个姓氏,我将其作为字符串接收。 然后我使用 djb2 将字符串散列成一个整数。它采用无符号字符 * 作为参数。我的程序的目标是使用链接创建一个哈希表来处理 collisons。
unsigned long djb2(unsigned char *str)
{
unsigned long hash = 5381;
int c;
while (c = *str++)
hash = ((hash << 5) + hash) + c; /* hash * 33 + c */
return hash;
}
我的代码如下 atm。
void insert(LinkedList<Person>* HashList1[], LinkedList<Person>* HashList2[], int listSize)
{
char * cstr;
string str;
cin >> str;
cstr = new char [str.size()+1];
strcpy (cstr, str.c_str());
int hashBucket1 = djb2(cstr) % listSize;
}
我收到上述错误,告诉我"char *"类型的参数与"无符号字符*"类型的参数不兼容。任何帮助都非常感谢
当您遇到这样的键入问题时,这是一个很好的迹象,表明您没有以最佳方式使用该语言。 在字符串和 C++ 字符之间来回切换是一种糟糕的代码气味。
修改dbjc
以使用字符串:
unsigned long djb2(const string& str)
{
unsigned long hash = 5381;
for(string::iterator it=str.begin();it!=str.end();it++)
hash = ((hash << 5) + hash) + *it; /* hash * 33 + character */
return hash;
}
这将大大简化您的插入:
void insert(LinkedList<Person>* HashList1[], LinkedList<Person>* HashList2[], int listSize){
string str;
cin >> str;
int hashBucket1;
hashBucket1 = djb2(str) % listSize;
}
最好的解决方案是修改dbjc
函数,正如@Steven Burnap所建议的那样。
如果您无法更改dbjc
则在dbjc
调用中将cstr
转换为unsigned char *
:
void insert(LinkedList<Person>* HashList1[], LinkedList<Person>* HashList2[], int listSize){
char * cstr;
string str;
cin >> str;
cstr = new char [str.size()+1];
strcpy (cstr, str.c_str());
int hashBucket1;
hashBucket1 = djb2((unsigned char *)cstr) % listSize; // <-- here is the change
}