将字符串转换为无符号字符 str

convert string to unsigned char str

本文关键字:字符 str 无符号 字符串 转换      更新时间:2023-10-16

我正在尝试将字符串转换为无符号字符*。我一直在绕圈子。 我的程序提示用户输入一个姓氏,我将其作为字符串接收。 然后我使用 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
}