c - 尝试将节点添加到链表中

标签 c

我一直在尝试将新节点添加到配置文件的链接列表中(例如 facebook 配置文件),但在启动时遇到运行时错误。这就是我得到的:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdlib.h>

typedef struct friend {
    char *name;
    int age;
    char gender;
    struct friend* next;
} friend;

void node_add(friend* new);

int main(int argc, char *argv[]) {
    friend amit;
    friend *new;

    amit.name = "amit";
    amit.age = 16;
    amit.gender = 'm';

    node_add(new);
    new->name = "amit";

    printf ("name: %s\n", new->name);
    system("PAUSE");    

    return 0;
}

void node_add(friend* new) {
    new = (friend* )malloc(sizeof(friend));
    friend* head = new;
    new -> next = head;
}

我现在正在尝试创建一个删除节点函数。我试图找到用户想要删除哪个节点,然后通过执行删除它

delete -> next = delete -> next -> next

问题是,我需要获取列表中的第一个节点。 这是我写的:

void node_delete(friend* delete) {
    friend *temp;
    char name[256];
    int i = 0, j = 0;

    printf ("Please enter the friend's name you want to delete: \n");
    fgets (name, 256, stdin);
    fgets (name, 256, stdin);

    while (0 == (strcmp(temp -> next -> name, delete -> next -> name))) {
        temp = friend -> next;
    }
    temp -> next = temp -> next -> next;
    free (delete);
}

最佳答案

编辑:

看来我的测试有点太快了,因为实际上这段代码存在一个非常严重的问题,但它很微妙:

main() 中,你实际上从来没有指向任何新的东西。它只是一个指向内存空间的乱码指针,有时可能有效,但大多数时候,效果很糟糕。

friend *new; // here's your problem; change this to:
friend *new = malloc(sizeof(friend));

此外,切勿强制转换 malloc 的结果。

重新编辑:

一个非常简单的链表实现可能看起来如何:

typedef struct _node node;
struct _node {
  void *payload;
  node *next;
};

node *create_node () {
  node *retval = malloc(sizeof(node));

  retval->payload = NULL;
  retval->next = NULL;

  return retval;
}

node *add_node (node *target) {
  if (target->next)
    return;

  node *next = create_node();
  node->next = next;
}

node *node_search (node *haystack, void *needle) {
  while (haystack) {
    if (!compare(needle, haystack->payload)) {
      return haystack;
    } else {
      haystack = haystack->next;
    }
  }

  return NULL;
}

删除和插入的实现留给读者作为练习。

关于c - 尝试将节点添加到链表中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10348493/

相关文章:

c++ - 数据结构 - 选择排序方法

c - 打印c中的字符

c++ - size_t 与 unsigned int 相比的大小

c - 重定向标准输出

c++ - 加速 FFTW 修剪以避免大量零填充

c - 如何让这个简单的 C 程序重新开始?

c - 请告诉我当返回多个变量时哪个变量被存储?

c - 读取 2kb txt 文件时出现段错误 (c)

c++ - 等级 2 导致所有机架集体中止

c - 使用预处理器的技巧#ifndef