z2521367787 发表于 2020-9-6 17:53:10

【C语言】通讯录系统设计中遇到的问题

各位大佬好!我用C语言编写了个通讯录系统,系统的要求就是小甲鱼视频当中的要求(见下图)。目前在删除通讯录这边碰到了bug。删除通讯录当中的问题就是当我执行删除操作后,整个主函数会直接结束,不知道为什么,还请各位大佬麻烦看看。

小甲鱼的要求:


全部代码:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

struct Address_book;

void addPreson(struct Address_book **);

void findPerson(struct Address_book *);

void changePerson(struct Address_book *);

void delPerson(struct Address_book **);

void displayContacts(struct Address_book *);

void freeContacts(struct Address_book *);

int main(void) {
    int input;
    char name;
    long long phone_number;
    struct Address_book *head = NULL;//头指针

    do {
      printf("请输入操作号码:\n"
               "1.插入新的联系人\t2.查找已有联系人\t3.更改已有联系人\n"
               "4.删除已有联系人\t5.显示当前通讯录\t6.退出通讯录");
      putchar('\n');
      scanf("%d", &input);
      if (input < 1 || input > 6) {
            printf("非法输入!");
            continue;
      }


      switch (input) {
            case 1 :
                addPreson(&head);
                break;
            case 2:
                findPerson(head);
                break;
            case 3:
                changePerson(head);
                break;
            case 4:
                delPerson(&head);
                break;
            case 5:
                displayContacts(head);
                break;
            case 6:
                freeContacts();
                break;
      }
    } while (input != 6);

    return 0;
}

struct Address_book {
    char name;
    long long phone_number;
    struct Address_book *next;
};

void addPreson(struct Address_book **head) {    //添加
    struct Address_book *previous;
    struct Address_book *new;

    new = (struct Address_book *) malloc(sizeof(struct Address_book));
    if (new == NULL) {
      printf("分配新空间失败,请重试!");
      exit(1);
    }

    //给new赋值
    printf("请输入添加的联系人姓名:");
    scanf("%s", new->name);
    printf("请输入添加的联系人电话:");
    scanf("%lld", &new->phone_number);

    if (*head != NULL) {
      previous = *head;
      //定义单链表尾部位置
      while (previous->next != NULL) {
            previous = previous->next;
      }
      //插入数据
      previous->next = new;
      new->next = NULL;
    } else {
      *head = new;
      new->next = NULL;
    }
}

void findPerson(struct Address_book *head) {    //查找
    char name;
    printf("请输入你想查找的联系人姓名:");
    scanf("%s", name);

    struct Address_book *object;
    object = NULL;
    while (head != NULL) {
      if (!strcmp(head->name, name)) {
            object = head;
            printf("查询完毕!\n");
            printf("联系人姓名:%s\n", name);
            printf("联系人电话%lld\n", object->phone_number);
            return;
      }
      head = head->next;
    }

    printf("未找到该联系人!\n");
}

void changePerson(struct Address_book *head) {//替换
    char name_1;
    printf("请输入替换人的姓名:");
    scanf("%s", name_1);

    while (head != NULL) {
      if (!strcmp(name_1, head->name)) {
            printf("请输入替换后的姓名:");
            scanf("%s", head->name);
            printf("请输入替换后的电话:");
            scanf("%lld", &head->phone_number);
            printf("替换成功!\n");
            return;
      }
      head = head->next;
    }
    printf("未找到该联系人!\n");
}

void delPerson(struct Address_book **head) { //删除指令
    char name;
    printf("请输入要删除的联系人姓名:");
    scanf("%s", name);

    struct Address_book *previous = NULL;//前一个指针
    struct Address_book *current = *head;   //当前要删除的指针

    while ((*head) != NULL) {
      if (!strcmp(current->name, name)) { //定位完毕,删除,结束
            previous->next = current->next;
            free(current);
            return;
      }
      previous = current;
      current = current->next;
    }

    printf("未找到该联系人!\n");//函数走到了最后,说明没能遍历到
}


void displayContacts(struct Address_book *head) {
    struct Address_book *current;
    current = head;
    if (current == NULL) {
      printf("通讯录为空!");
    }
    while (current != NULL) {
      printf("姓名:%s\n", current->name);
      printf("电话:%lld\n", current->phone_number);
      current = current->next;
    }

    putchar('\n');
}

void freeContacts(struct Address_book *head) {
    struct Address_book *temp;
    while (head != NULL) {
      temp = head;
      free(head);
      head = temp->next;
    }
}

z2521367787 发表于 2020-9-6 17:54:35

各位大佬不好意思,之前发帖一直碰到问题,所以只能把全部代码一次性发出来了,还麻烦各位大佬找到删除函数了

巴巴鲁 发表于 2020-9-6 19:41:52

代码太长了,我就说哪个地方改吧
144行初始化有误,改为struct Address_book *previous = *head;

巴巴鲁 发表于 2020-9-7 19:00:39

抱歉我说错了,删除函数改成这样
void delPerson(struct Address_book **head) { //删除指令
    char name;
    printf("请输入要删除的联系人姓名:");
    scanf("%s", name);

    struct Address_book *previous = *head;//前一个指针
    struct Address_book *current = *head;   //当前要删除的指针

    while ((*head) != NULL) {
      if (!strcmp(current->name, name)) { //定位完毕,删除,结束
            previous->next = current->next;
            free(current);
            return;
      }
      current = current->next;
    }

    printf("未找到该联系人!\n");//函数走到了最后,说明没能遍历到
}
另外你的56行释放函数也要改一下
freeContacts(head); // 不放参数?

巴巴鲁 发表于 2020-9-7 19:01:28

昨天我都忘了。。。可以忽略我上一个答案

巴巴鲁 发表于 2020-9-9 06:19:40

没有解决吗?我试的可以啊。看看这个帖子{:10_266:}

z2521367787 发表于 2020-9-13 09:48:41

巴巴鲁 发表于 2020-9-7 19:00
抱歉我说错了,删除函数改成这样
另外你的56行释放函数也要改一下

太感谢了!
页: [1]
查看完整版本: 【C语言】通讯录系统设计中遇到的问题