将字符串转换为unsigned char str

时间:2012-05-26 18:38:21

标签: c++ linked-list

我正在尝试将字符串转换为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 *“类型的参数不兼容。非常感谢任何帮助

2 个答案:

答案 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
}