c语言 - 如何修复这些无效类型的参数(链接列表/结构)并确保它们不会再次发生?



所以,在大学的这个学期,我们开始学习C。我以为我掌握了指针的概念,但现在我意识到我真的需要你的帮助。作为最终分配,我们需要编写一个程序,该程序能够从文件中读取一组单词,将它们全部放入链表中,然后对其进行排序(按字母顺序和按其他标准)。我目前正在尝试编写这部分代码,但面临很多"无效类型参数 ->"等,所以我真的需要帮助了解我做错了什么,如何修复它,以及如何确保它不会再次发生由于我的无知。


typedef struct local{
char *name;
struct local *next;
}t_local;
void printlocalsalphabetical(t_local *header_l){
createlistlocals(*header_l);
sort_alphabetical(*header_l);
t_local l   = header_l->next;
while (l){
puts(l->name);
l=l->next;
}
}
void crialistlocals(t_local *header_l){
FILE *fp;
t_local *aux = header_l->next;
char line[150];
char *namel;
fp = fopen("locais.txt","r");
while (!feof(fp)){
fgets(line, 100, fp);
namel = strtok(line, '/');
aux->name = namel;
aux->next = header_l;
header_l= aux;
}
}
void sort_alphabetical(t_local *header_l){
int swapped;
t_local *ptr1;
t_local *lptr = NULL;

if (header_l == NULL)
return;
do
{
swapped = 0;
ptr1 = header_l;
while (ptr1->next != lptr)
{
if (ptr1->name > ptr1->prox->name)
{
swap(ptr1, ptr1->next);
swapped = 1;
}
ptr1 = ptr1->next;
}
lptr = ptr1;
}
while (swapped);
}
void swap(t_local *a, t_local *b)
{
char *temp = a->name;
a->name = b->name;
b->name = strdup(temp);
}

t_local *create_headerL(void){
t_local *list = (t_local*)malloc(sizeof(t_local));
if (list != NULL)
list->next = NULL;
return lista;
}
int main()
{
t_local *header_l = create_headerL();
printlocalsalphabetical(*header_l);
return 0;
}

我真的很挣扎,由于我无法理解它,我开始真正吓坏了,所以非常非常欢迎所有和任何帮助

您必须知道何时使用指针,何时不使用指针。 (如果使用链表,通常需要指针。您还必须知道星号何时定义指针以及何时取消引用指针。

void printlocalsalphabetical(t_local *header_l)

这是定义。header_l是指向t_local的指针。

createlistlocals(*header_l);
sort_alphabetical(*header_l);

这些是函数调用,其中*header_l是取消引用指针的表达式,给出t_local。这两个函数都想要一个指向t_local的指针,所以去掉星号。

t_local l = header_l->next;

在这里,你定义了一个t_local,但header_l->next是指向t_local的指针,l也应该是一个指针:更改为t_local *l

puts(l->name);
l=l->next;

仅当左侧是指向结构或联合体的指针时,->运算符才有效。使用.将修复语法错误,但不会修改代码。实际上,该代码已经通过将l类型更改为t_local *来修复。

(我在这里只看了第一个函数,但我希望你明白这个想法。

所以没有必要惊慌失措。保持冷静的头脑,阅读错误消息,确定是否需要指针,然后修复代码。错误消息是为了帮助您,而不是惹恼您。

最新更新