C语言数据结构顺序表-通讯录管理系统的设计与实现(附带源码)

用链表或者顺序表实现以下系统,完成线性表的建立(至少包括10个结点),以及线性表中信息(结点)的插入、查找、删除、修改、输出等操作,。若能用“文件”存储数据,可加分。

1.通讯录管理系统的设计与实现

(1)通讯者信息包括:编号(char num[10])、姓名(char name[10])、性别(char sex[10])、电话(char phone[20])、公司名称(char address[50])

2)除了总的模块要求外,还需a.统计通讯录中男女比例;b.显示出同一公司中的人的信息。

运行主页面效果:

C语言数据结构顺序表-通讯录管理系统的设计与实现(附带源码)_第1张图片

 主菜单函数:

int main() {
    SeqList L;
    InitList(&L);
    int choice;
    do {
        printf("\n");
        printf("**********通讯录管理系统**********\n");
        printf("**********代码+QQ:3125841747**********\n");
        printf("**********看主页的连接方式**********\n");
        printf("1. 添加通讯者信息\n");
        printf("2. 删除通讯者信息\n");
        printf("3. 查找通讯者信息\n");
        printf("4. 修改通讯者信息\n");
        printf("5. 统计通讯录中男女比例\n");
        printf("6. 显示出同一公司中的人的信息\n");
        printf("7. 显示通讯录中所有人员信息\n");
        printf("0. 退出通讯录管理系统\n");
        printf("请选择操作序号:");
        scanf("%d", &choice);
       

添加联系人:

C语言数据结构顺序表-通讯录管理系统的设计与实现(附带源码)_第2张图片

switch (choice) {
            case 1: { // 添加通讯者信息
                Person p;
                printf("请输入编号:");
                scanf("%s", p.num);
                printf("请输入姓名:");
                scanf("%s", p.name);
                printf("请输入性别:");
                scanf("%s", p.sex);
                printf("请输入电话:");
                scanf("%s", p.phone);
                printf("请输入公司名称:");
                scanf("%s", p.address);
                if (ListInsert(&L, L.length + 1, p)) {
                    printf("添加成功!\n");
                } else {
                    printf("添加失败!\n");
                }
                break;

 查看所有联系人:

C语言数据结构顺序表-通讯录管理系统的设计与实现(附带源码)_第3张图片

// 根据编号查找顺序表L中的元素,并将其保存到e中
int GetElem(SeqList L, char *num, Person *e) {
    for (int i = 0; i < L.length; i++) {
        if (strcmp(L.data[i].num, num) == 0) { // 如果编号匹配
            *e = L.data[i]; // 将元素保存到e中
            return i + 1;   // 返回元素在顺序表中的位置
        }
    }
    return 0; // 没有找到匹配的元素

 查找联系人:

C语言数据结构顺序表-通讯录管理系统的设计与实现(附带源码)_第4张图片

case 3: { // 查找通讯者信息
                char num[10];
                printf("请输入要查找的通讯者编号:");
                scanf("%s", num);
                Person p;
                if (GetElem(L, num, &p)) { // 如果编号存在
                    printf("编号:%s,姓名:%s,性别:%s,电话:%s,公司名称:%s\n", p.num, p.name, p.sex, p.phone, p.address);
                } else { // 如果编号不存在
                    printf("没有找到编号为%s的通讯者信息!\n", num);
                }
                break;
            }

修改联系人:

C语言数据结构顺序表-通讯录管理系统的设计与实现(附带源码)_第5张图片 

case 4: { // 修改通讯者信息
                char num[10];
                printf("请输入要修改的通讯者编号:");
                scanf("%s", num);
                Person p;
                if (GetElem(L, num, &p)) { // 如果编号存在
                    printf("请输入修改后的信息:\n");
                    printf("请输入编号:");
                    scanf("%s", p.num);
                    printf("请输入姓名:");
                    scanf("%s", p.name);
                    printf("请输入性别:");
                    scanf("%s", p.sex);
                    printf("请输入电话:");
                    scanf("%s", p.phone);
                    printf("请输入公司名称:");
                    scanf("%s", p.address);
                    if (ListUpdate(&L, GetElem(L, num, &p), p)) {
                        printf("修改成功!\n");
                    } else {
                        printf("修改失败!\n");
                    }
                } else { // 如果编号不存在
                    printf("没有找到编号为%s的通讯者信息!\n", num);
                }
                break;

统计男女性别:

C语言数据结构顺序表-通讯录管理系统的设计与实现(附带源码)_第6张图片 

// 统计通讯录中男女比例
void CountGenderRatio(SeqList L) {
    int maleCount = 0, femaleCount = 0;
    for (int i = 0; i < L.length; i++) {
        if (strcmp(L.data[i].sex, "男") == 0) {
            maleCount++;
        } else if (strcmp(L.data[i].sex, "女") == 0) {
            femaleCount++;
        }
    }
    printf("男性人数:%d,女性人数:%d\n", maleCount, femaleCount);

按公司查找人员:

C语言数据结构顺序表-通讯录管理系统的设计与实现(附带源码)_第7张图片 

 

// 显示出同一公司中的人的信息
void ShowSameAddressPerson(SeqList L, char *address) {
    printf("公司名称为%s的人员信息如下:\n", address);
    for (int i = 0; i < L.length; i++) {
        if (strcmp(L.data[i].address, address) == 0) {
            printf("编号:%s,姓名:%s,性别:%s,电话:%s\n", L.data[i].num, L.data[i].name, L.data[i].sex, L.data[i].phone);
        }
    }
}

 全局函数,定义结构体:

// 定义通讯者信息的结构体
typedef struct {
    char num[10];     // 编号
    char name[10];    // 姓名
    char sex[10];     // 性别
    char phone[20];   // 电话
    char address[50]; // 公司名称
} Person;

你可能感兴趣的:(数据结构,链表,算法)