c语言小项目——通讯录(动态版)

目录

预处理

菜单打印

代码整体框架

查找函数的分装

存放100个用户信息(名字,电话,性别,地址,年龄)

初始化通讯录

动态增加通讯录容量

增加好友信息

删除好友信息

查找好友信息

修改好友信息

打印好友信息

按名字排序好友信息

退出销毁内存


 

预处理

#pragma once
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#define DEFAULT_SZ 3
#define MAX_NAME 20
#define MAX_SEX 5
#define MAX_TELE 12
#define MAX_ADDR 30
enum Option
{
	EXIT,//0
	ADD,//1
	DEL,//2
	SEARCH,//3
	MODIFY,//4
	SHOW,//5
	SORT//6
};


菜单打印

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;
    //创建通讯录
    struct Contact con;
    //初始化通讯录
    InitContact(&con);
    do
    {
        menu();
        printf("请选择:");
        scanf("%d", &input);
        switch (input)
        {
        case ADD:
            AddContact(&con);   // 增加一个信息到通讯录
            break;
        case DEL:
            DelContact(&con);    //删除指定的联系人
            break;
        case SEARCH:
            SearchContact(&con);  //查找指定人的信息
            break;
        case MODIFY:
            ModifyContact(&con);   //修改指定人的信息
            break;
        case SHOW:
            ShowContact(&con);   //打印通讯录的信息
            break;
        case SORT:
            SortContact(&con);  //根据名字进行排序
            break;
        case EXIT:
            printf("退出通讯录\n");  //退出通讯录
            break;
        default:
            printf("输入错误\n");
 
        }
 
    } while(input);
    return 0;
}


查找函数的分装

static int  FindByName(const struct Contact* ps, char name[MAX_NAME])//查找函数
{
    int i = 0;
    for (i = 0; i < ps->size; i++)
    {
        if (0 == strcmp(ps->data[i].name, name))
        {
            return i;
        }
    }
    return -1;
}


存放100个用户信息(名字,电话,性别,地址,年龄)

struct PeoiInfor
{
	char name[MAX_NAME];
	int age;
	char sex[MAX_SEX];
	char tele[MAX_TELE];
	char addr[MAX_ADDR];
};
struct Contact
{
	struct PeoiInfor *data;
	int capacity;//当前通讯里的最大容量
	int size;//记录当前已有元素的个数
};


初始化通讯录

void InitContact(struct Contact* ps)
{
	ps->data =(struct PeoiInfor*) malloc(DEFAULT_SZ * sizeof(struct PeoiInfor));
	if (ps->data == NULL)
	{
		return;

	}
	ps->capacity = DEFAULT_SZ;
	ps->size = 0;
}

动态增加通讯录容量

void CheckCapacity(struct Contact* ps)
{
	if (ps->size == ps->capacity)
	{
		struct PeoiInfor*ptr= realloc(ps->data, (ps->capacity + 2) * sizeof(struct PeoiInfor));
		if (ptr != NULL)
		{
			ps->data = ptr;
			ps->capacity += 2;
			printf("增容成功\n");
		}
		else
			printf("增容失败\n");
	}
}


增加好友信息

void AddContact(struct Contact* ps)
{
	//检测当前通讯录的容量
	//如果满了增加容量
	CheckCapacity(ps);
	
		printf("请输入名字:");
		scanf("%s", ps->data[ps->size].name);
		printf("请输入年龄:");
		scanf("%d", &(ps->data[ps->size].age));
		printf("请输入性别:");
		scanf("%s", ps->data[ps->size].sex);
		printf("请输入电话:");
		scanf("%s", ps->data[ps->size].tele);
		printf("请输入地址:");
		scanf("%s", ps->data[ps->size].addr);
		ps->size++;
		printf("用户添加成功\n");
	
}


删除好友信息

void DelContact(struct Contact* ps)
{
	char name[MAX_NAME];
	printf("请输入要删除人的名字\n");
	scanf("%s", &name);
	//1.查找要删除的人在什么位置
	int pos = FindByName(ps, name);//找到了返回下标,找不到返回-1.
	if (pos == -1)
	{
		printf("要删除的人不存在\n");
	}
	else
	{
		//删除数据
		int j = 0;
		for (j = 0; j < (ps->size - 1); j++)
		{
			ps->data[j] = ps->data[j + 1];
		}
		ps->size--;
		printf("删除成功\n");
	}
}

查找好友信息

void SearchContact(const struct Contact* ps)
{
	printf("请输入要查找人的名字\n");
	char name[MAX_NAME];
	scanf("%s", &name);
	int i = FindByName(ps, name);
	if (i == -1)
	{
		printf("查无此人\n");
	}
	else
	{
		printf("%-20s\t%-4s\t%-5s\t%-12s\t%-20s\n", "名字", "年龄", "性别", "电话", "地址");
		printf("%-20s\t%-4d\t%-5s\t%-12s\t%-20s\n",
			ps->data[i].name,
			ps->data[i].age,
			ps->data[i].sex,
			ps->data[i].tele,
			ps->data[i].addr);
	}
}


修改好友信息

void ModifyContact(struct Contact* ps)
{
	int pos = 0;
	char name[MAX_NAME];
	printf("请输入要修改人的名字:");
	scanf("%s", name);
	 pos = FindByName(ps, name);
	if (pos == -1)
		printf("要修改人的信息不存在\n");
	else
	{
		printf("请输入名字:");
		scanf("%s", ps->data[pos].name);
		printf("请输入年龄:");
		scanf("%d", &(ps->data[pos].age));
		printf("请输入性别:");
		scanf("%s", ps->data[pos].sex);
		printf("请输入电话:");
		scanf("%s", ps->data[pos].tele);
		printf("请输入地址:");
		scanf("%s", ps->data[pos].addr);
		ps->size++;
		printf("用户修改成功\n");
	}
}


打印好友信息

void ShowContact(const struct Contact* ps)
{
	if (ps->size == 0)
		printf("通讯录为空\n");
	else
	{
		int i = 0;
		//标题
		printf("%-20s\t%-4s\t%-5s\t%-12s\t%-20s\n", "名字", "年龄", "性别", "电话", "地址");
		for (i = 0; i < ps->size; i++)
		{
			printf("%-20s\t%-4d\t%-5s\t%-12s\t%-20s\n",
				ps->data[i].name,
				ps->data[i].age,
				ps->data[i].sex,
				ps->data[i].tele,
				ps->data[i].addr);
		}
	}
}


按名字排序好友信息

int compar(const void* e1,const void* e2)
{
    return strcmp(((struct PeoiInfor*)e1)->name, ((struct PeoiInfor*)e2)->name);
}
void SortContact(struct Contact *ps)
{
    qsort(ps->data, ps->size, sizeof(ps->data[0]), compar);
    if (ps->size == 0)
        printf("通讯录为空\n");
    else
    {
        int i = 0;
        //标题
        printf("%-20s\t%-4s\t%-5s\t%-12s\t%-20s\n", "名字", "年龄", "性别", "电话", "地址");
        for (i = 0; i < ps->size; i++)
        {
            printf("%-20s\t%-4d\t%-5s\t%-12s\t%-20s\n",
                ps->data[i].name,
                ps->data[i].age,
                ps->data[i].sex,
                ps->data[i].tele,
                ps->data[i].addr);
        }
    }
}

退出销毁内存

//退出销毁内存
void DestroyContact(struct Contact* ps)
{
	free(ps->data);
	ps->data;
}

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

binary~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值