鱼C论坛

 找回密码
 立即注册
查看: 1512|回复: 1

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

[复制链接]
发表于 2020-9-6 17:51:06 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

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

小甲鱼的要求

小甲鱼的要求


我的删除函数:
void delPerson(struct Address_book **head) { //删除指令
    char name[40];
    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");//函数走到了最后,说明没能遍历到
}

其中Address_book是我创建的结构体,用于存放联系人姓名(char类型数组)和联系人电话(long long类型):
struct Address_book {
    char name[40];
    long long phone_number;
    struct Address_book *next;
};

主函数:
int main(void) {
    int input;
    char name[40];
    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;
}

最后是整个代码,为了方便看我把最主要要解决的部分放在上面了,怕有其他问题,所以就把整个代码放最后了
#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[40];
    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[40];
    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[40];
    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[40];
    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[40];
    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;
    }
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-9-8 21:40:33 | 显示全部楼层
本帖最后由 superbe 于 2020-9-8 21:52 编辑

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

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

    while (current != NULL) {               //判断当前节点是否为NULL
        if (!strcmp(current->name, name)) { //定位完毕,删除,结束
            if (previous == NULL)           //头节点即是要删除的节点的情况
                *head = current->next;
            else
                previous->next = current->next;
            free(current);
            return;
        }
        previous = current;
        current = current->next;
    }

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

另外,主函数调用freeContacts()漏掉了参数,改成:
freeContacts(head);
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-13 06:15

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表