我正在尝试将字符串转换为unsigned char *。而且我一直在圈子里跑。我的程序提示用户输入一个姓氏作为字符串。然后我使用djb2将字符串散列为整数。它将unsigned char *作为参数。我的程序的目标是使用链接来创建一个哈希表来处理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 *“与”unsigned char *“类型的参数不兼容。非常感谢任何帮助
答案 0 :(得分:4)
当您输入此类问题时,它表明您没有以最佳方式使用该语言。在C ++中在字符串和char *之间来回转换是bad code smell。
修改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;
}
答案 1 :(得分:0)
最好的解决方案是修改dbjc
函数,如@Steven Burnap所建议。
如果您无法更改dbjc
,请在cstr
电话中将unsigned char *
投放到dbjc
:
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
}