0

我有一个 LinkedList 实现,它包含包含单词和其他一些信息的结构。在 LinkedList 我有一个函数,它检查一个单词是否已经包含在列表中的一个结构中。问题是,这每次都返回 0。知道这是为什么吗?

if(strcmp(ll->value->word, word))这编译得很好,除了语句之外,这个函数的每个方面都有效。

编辑:对不起,忘记添加!

int llContains(LinkedList* ll, char* word){

    LinkedList* nn= ll;
    if(nn != NULL){
       for(int i=0; nn != NULL; i++){
           if(!strcmp(ll->value->word, word)){
               return i;
           }
           nn = nn->next;
       }
    } else {
       return -1;
    }
}
4

2 回答 2

0

代码具有未定义的行为,因为函数中存在一条路径,该路径没有显式return: 如果未执行return内部。for

请注意,当字符串相等时strcmp()返回,因此如果字符串不匹配,则内部将为“true”。这意味着如果列表中的第一个条目不相等,则将返回。0iffor0

改成:

int llContains(LinkedList* ll, char* word){

    LinkedList* nn= ll;
    if(nn != NULL){
       for(int i=0; nn != NULL; i++){
           if(strcmp(ll->value->word, word) == 0){
               return i;
           }
           nn = nn->next;
       }
    }

    /* ALWAYS return a value. */
    return -1;
}
于 2013-05-09T07:37:02.013 回答
0

在“return i”之前添加一些调试信息

int llContains(LinkedList* ll, char* word){

LinkedList* nn= ll;
if(nn != NULL){
   for(int i=0; nn != NULL; i++){
       if(strcmp(ll->value->word, word)){
           printf("Linked->word : %s, word : %s\n",ll->value->word, word);
           return i;
       }
       nn = nn->next;
   }
} else {
   return -1;
}

}

试试这个,让我们看看你有什么

于 2013-05-09T07:37:47.050 回答