c语言实现简单通讯录~

这是一个使用C语言编写的简单通讯录程序,包括增加联系人、删除指定联系人、查找联系人信息、修改联系人信息、显示所有联系人以及按不同字段排序等功能。程序通过结构体存储联系人信息,并利用qsort函数进行排序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这是较为简单的通讯录版本。
通讯录存放的信息:姓名、年龄、性别、地址、电话
功能:

  1. 增加联系人
  2. 删除指定联系人
  3. 查找指定联系人的信息
  4. 修改指定联系人的信息
  5. 显示所有联系人的信息
  6. 排序(名字+年龄)

在这里插入图片描述
源代码如下:
一共有2个源文件,1个头文件
头文件:

//contact.h
#include<stdio.h>
#include<memory.h>
#include<assert.h>
#include<stdlib.h>
#include<string.h>

#define MAX 100
#define NAME_MAX 20
#define SEX_MAX 5
#define ADDR_MAX 30
#define TELE_MAX 12



//人的信息的定义
typedef struct PeoInfo
{
    char name[NAME_MAX];
    int age;
    char sex[SEX_MAX];
    char addr[ADDR_MAX];
    char tele[TELE_MAX];
}PeoInfo;


typedef struct Contact
{
    PeoInfo data[MAX];//存放人的信息
    int sz;//用来表示当前已经放了几个人的信息了
}Contact;


//函数声明
//初始化通讯录
void InitContact(Contact* pc);
//增加一个人的信息
void AddContact(Contact* pc);
//显示通讯录中的信息
void ShowContact(const Contact* pc);
//删除指定联系人
void DelContact(Contact* pc);
//查找指定联系人
void SearchContact(const Contact* pc);
//修改指定联系人
void ModifyContact(Contact* pc);
//排序联系人
void SortContact(Contact* pc);

源文件——test.c

//test.c
#include"contact.h"

void menu()
{
    printf("********************************\n");
    printf("****** 1. add     2. del *******\n");
    printf("****** 3. search  4. modify ****\n");
    printf("****** 5. show    6. sort ******\n");
    printf("*********** 0. exit ************\n");
    printf("********************************\n");
}
int main()
{
    int input = 0;
    //创建通讯录
    Contact con;
    //初始化通讯录
    InitContact(&con);

    do
    {
        menu();
        printf("请选择\n");
        scanf("%d", &input);
        switch (input)
        {
        case 1:
            AddContact(&con);
            break;
        case 2:
            DelContact(&con);
            break;
        case 3:
            SearchContact(&con);
            break;
        case 4:
            ModifyContact(&con);
            break;
        case 5:
            ShowContact(&con);
            break;
        case 6:
            SortContact(&con);
            break;
        case 0:
            printf("退出通讯录\n");
            break;
        default:
            printf("选择错误\n");
            break;
        }
    } while (input);
}

源文件——Contact.c

//contact.c

#include"contact.h"


//初始化通讯录
void InitContact(Contact* pc)
{
    pc->sz = 0;
    memset(pc->data, 0, sizeof(pc->data));//这边的pc->data实际上就是数组名,放在sizeof里面就是计算整个数组的大小
}


//增加一个人的信息
void AddContact(Contact* pc)
{
    assert(pc);
    //判断通讯录是否已满
    if (pc->sz == MAX)
    {
        printf("通讯录已满,无法添加\n");
        return;
    }
    //没有满就增加一个人的信息
    printf("请输入名字:");
    scanf("%s", pc->data[pc->sz].name);
    printf("请输入年龄:");
    scanf("%d", &(pc->data[pc->sz]).age);
    printf("请输入性别:");
    scanf("%s", pc->data[pc->sz].sex);
    printf("请输入地址:");
    scanf("%s", pc->data[pc->sz].addr);
    printf("请输入电话:");
    scanf("%s", pc->data[pc->sz].tele);
    pc->sz++;
}


//显示通讯录中的信息
void ShowContact(const Contact* pc)
{
    assert(pc);
    int i = 0;
    printf("%-20s\t%-4s\t%-5s\t%-20s\t%-12s\t\n", "姓名", "年龄", "性别", "地址", "电话");
    for (i = 0; i < pc->sz; i++)
    {
        printf("%-20s\t%-4d\t%-5s\t%-20s\t%-12s\t\n",    pc->data[i].name,
                                                        pc->data[i].age,
                                                        pc->data[i].sex,
                                                        pc->data[i].addr,
                                                        pc->data[i].tele);
    }
}



int FindByName(const Contact* pc, char name[])
{
    int i = 0;
    for (i = 0; i < pc->sz; i++)
    {
        if (strcmp(pc->data[i].name, name) == 0)
        {
            return i;
        }
    }
    return -1;
}

//删除指定联系人
void DelContact(Contact* pc)
{
    assert(pc);
    if (pc->sz == 0)
    {
        printf("通讯录为空,无法删除\n");
        return;
    }
    //找到要删除的人
    char name[NAME_MAX] = { 0 };
    printf("请输入要删除的人的名字\n");
    scanf("%s", name);
    int ret = FindByName(pc, name);
    if (-1 == ret)
    {
        printf("要删除的人不存在\n");
        return;
    }
    int i = 0;
    //删除
    for (i = ret; i < pc->sz - 1; i++)
    {
        pc->data[i] = pc->data[i + 1];
    }
    pc->sz--;
    printf("删除成功\n");

}


//查找指定联系人
void SearchContact(const Contact* pc)
{
    assert(pc);
    char name[NAME_MAX] = { 0 };
    printf("请输入你要查找的联系人姓名\n");
    scanf("%s", name);
    int pos = FindByName(pc, name);
    if (-1 == pos)
    {
        printf("该联系人不存在\n");
        return;
    }
    //找到了就打印
    printf("%-20s\t%-4s\t%-5s\t%-20s\t%-12s\t\n", "姓名", "年龄", "性别", "地址", "电话");
    printf("%-20s\t%-4d\t%-5s\t%-20s\t%-12s\t\n",    pc->data[pos].name,
                                                    pc->data[pos].age,
                                                    pc->data[pos].sex,
                                                    pc->data[pos].addr,
                                                    pc->data[pos].tele);
}


//修改指定联系人
void ModifyContact(Contact* pc)
{
    assert(pc);
    char name[NAME_MAX] = { 0 };
    printf("请输入你要修改信息的联系人姓名\n");
    scanf("%s", name);
    int pos = FindByName(pc, name);
    if (-1 == pos)
    {
        printf("该联系人不存在\n");
        return;
    }
    //修改
    int ret = 0;
    do
    {
        printf("请输入你想修改什么(一次仅修改一项 ):\n");
        printf("%-4s\t%-4s\t%-4s\t%-4s\t%-4s\t%-4s\t\n", "1:姓名", "2:年龄", "3:性别", "4:地址", "5:电话", "0:退出");
        scanf("%d", &ret);
        switch (ret)
        {
        case 1:
            printf("请输入名字:\n");
            scanf("%s", pc->data[pos].name);
            break;
        case 2:
            printf("请输入年龄:\n");
            scanf("%d", &(pc->data[pos]).age);
            break;
        case 3:
            printf("请输入性别:\n");
            scanf("%s", pc->data[pos].sex);
            break;
        case 4:
            printf("请输入地址:\n");
            scanf("%s", pc->data[pos].addr);
            break;
        case 5:
            printf("请输入电话:\n");
            scanf("%s", pc->data[pos].tele);
            break;
        case 0:
            printf("修改完成\n");
            break;
        }
    } while (ret);
}


int cmp_char_name(const void* e1, const void* e2)
{
    return strcmp(((Contact*)e1)->data->name , ((Contact*)e2)->data->name);
}
int cmp_char_sex(const void* e1, const void* e2)
{
    return strcmp(((Contact*)e1)->data->sex, ((Contact*)e2)->data->sex);
}
int cmp_char_addr(const void* e1, const void* e2)
{
    return strcmp(((Contact*)e1)->data->addr, ((Contact*)e2)->data->addr);
}
int cmp_char_tele(const void* e1, const void* e2)
{
    return strcmp(((Contact*)e1)->data->tele, ((Contact*)e2)->data->tele);
}
int cmp_int(const void* e1, const void* e2)
{
    return ((Contact*)e1)->data->age - ((Contact*)e2)->data->age;
}


//排序联系人
void SortContact(Contact* pc)
{
    assert(pc);
    printf("请输入你想按照什么方式排序:\n");
    printf("%-4s\t%-4s\t%-4s\t%-4s\t%-4s\t%-4s\t\n", "1:姓名", "2:年龄", "3:性别", "4:地址", "5:电话","0:退出");
    int ret = 0;
    scanf("%d", &ret);
    switch (ret)
    {
    case 1:
        qsort(pc->data, pc->sz, sizeof(pc->data[0]), cmp_char_name);
        break;
    case 2:
        qsort(pc->data, pc->sz, sizeof(pc->data[0]), cmp_int);
        break;
    case 3:
        qsort(pc->data, pc->sz, sizeof(pc->data[0]), cmp_char_sex);
        break;
    case 4:
        qsort(pc->data, pc->sz, sizeof(pc->data[0]), cmp_char_addr);
        break;
    case 5:
        qsort(pc->data, pc->sz, sizeof(pc->data[0]), cmp_char_tele);
        break;
    case 0:
        printf("退出排序\n");
        break;
    default:
        printf("输入错误\n");
        break;
    }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值