在c

时间:2018-03-05 18:46:53

标签: c optimization

我正在尝试解决扫描char *星值的过程中出现的问题。

struct Property  {
unsigned int shift;
int mask;
char * str[4];
 } 
human [] = {
{0, 1, {"fe", "ma"}},
{1, 1, {"du", "cl"}},
{2, 1, {"nh", "ha"}},
{3, 1, {"sk", "tr"}},
{4, 3, {"bn", "rd", "bw", "bk"}},
{6, 3, {"bu", "ge", "gy", "da"}},
};

int find(char*  w){
int i;
int j;
for (i = 0; i < (sizeof(human)/ sizeof(struct Property)); i++){
    for (j = 0; j < 4 ; j++){
            if (human[i].str[j] == w)
                return i;
    }
}
}


int main(){

char* w ;
scanf("%s", w);
int k = find(w);
printf("k is %d", k);
return 0;
}

Clion编译器说&#39;指针参数w可以指向const&#39;。所以在我的main()中我尝试使用我的函数扫描w作为数组或char *。

更新建议。

struct Property {
unsigned int shift;
int mask;
char * st[4];
} human [] = {
    {0, 1, {"fe", "ma"}},
    {1, 1, {"du", "cl"}},
    {2, 1, {"nh", "ha"}},
    {3, 1, {"sk", "tr"}},
    {4, 3, {"bn", "rd", "bw", "bk"}},
    {6, 3, {"bu", "ge", "gy", "da"}},
};

int find(char*  w)
{
int i;
int j;
for (i = 0; i < (sizeof(human)/ sizeof(struct Property)); i++)
{
    for (j = 0; j < 4 ; j++)
    {
            if ((strcmp(human[i].st[j], w)) == 0)
                return i;
            else
                continue;
    }
}
return -1;
}


int main()
{

char* w = malloc(sizeof(char*));
scanf("%99s", w);
int k = find(w);
if (k != -1 )
    printf("k is %d", k);
if (k == -1) { printf("%s","Error");}
return 0;
}

仍然没有输出。我真的相信,有些事情仍然是错误的

1 个答案:

答案 0 :(得分:4)

有几个问题 -

  • 将内存分配给w。其他明智的方法是将未初始化的指针传递给scanf是未定义的行为。 (您也可以动态分配内存)

    char w[100];
    if( scanf("%99s",w) != 1 ){
       /* Handle error */
    }
    
  • 可以使用strcmp比较两个字符串。使用==运算符不是正确的方法。

    if ( strcmp(human[i].str[j], w) == 0 )
    
  • 此外,您应该始终从函数中返回一些内容。即使没有任何匹配,也应该返回一些东西。但你没有遵守那份合同。编译抱怨。

    for(..){
      ...
    }
    return -1; /* denoting invalid index - search failed*/
    
  • 您可以轻松地将参数作为const char *传递,因为您没有更改它的值(字符串的内容)。