通讯录 C语言实现

通讯录 C语言实现

第一步部分 头文件

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<assert.h>
#include<string.h>
#include<stdlib.h>

#define NAME_MAX 20
#define DIZHI_MAX 10
#define TEM_MAX 12
#define DATA_MAX 1000
#define SEX_MAX  5

typedef struct people
{
	char name[NAME_MAX];
	int  age;
	char sex[SEX_MAX];
	char dizhi[DIZHI_MAX];
	char tem[TEM_MAX];
}people;

typedef struct contact
{
	people data[DATA_MAX]; //
	int size;
}contact;

enum choose
{
	EXIT, //0
	ADD,
	DEL,
	SEARCH,
	MODIFY,
	SORT,
	PRINTF
};


void initcontact(contact* p);

void addcontact(contact* p);

void delcontact(contact* p);

void searchcontact(contact* p);

void modifycontact(contact* p);

void printfcontact(contact* p);

void sortcontact(contact* p);

第二部分 测试

#define _CRT_SECURE_NO_WARNINGS 1
#include"contact.h"

void menu()
{
	printf("********1.add****************\n");
	printf("********2.del****************\n");
	printf("********3.search*************\n");
	printf("********4.modify*************\n");
	printf("********5.sort***************\n");
	printf("********6.printf*************\n");
	printf("********0.exit***************\n");
	printf("*****************************\n");
	printf("*****************************\n");
}

void test()
{
	int input;
	 contact con;
	initcontact(&con);
	do
	{
		menu();
		printf("请选择功能\n");
		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 SORT:
			sortcontact(&con);
			break;
		case PRINTF:
			printfcontact(&con);
			break;
		case EXIT:
			printf("退出成功!\n");
			break;
		default:
			printf("选择错误!");
			break;
		}
	} while (input);
}
int main()
{
	test();
	return 0;
}

第三部分 函数实现

#define _CRT_SECURE_NO_WARNINGS 1
#include"contact.h"


void initcontact(contact* p) //
{
	assert(p);
	p->size = 0;
	memset(p->data, 0, sizeof(p->data)); //
}
void addcontact(contact* p)
{
	if (p->size == DATA_MAX)
	{
		printf("存不下了!\n");
	}
	else
	{
		printf("请输入姓名:\n");
		scanf("%s", p->data[p->size].name);
		printf("请输入年龄:\n");
		scanf("%d", &p->data[p->size].age);//
		printf("请输入性别:\n");
		scanf("%s", p->data[p->size].sex);
		printf("请输入地址:\n");
		scanf("%s", p->data[p->size].dizhi);
		printf("请输入电话:\n");
		scanf("%s", p->data[p->size].tem);
		p->size++;//
		printf("输入完成!\n");
	}
}

int findcontact(const contact* p, char del[NAME_MAX])//
{
	for (int i = 0;i < p->size;i++)
	{
		if (0 == strcmp(p->data[i].name, del))//
		{
			return i;
		}
	}
	return -1;
}
void delcontact(contact* p)
{
	printf("请输入要铲除人的姓名!!!\n");
	char del[NAME_MAX];//
	scanf("%s", del);
	int pos=findcontact(p,del);//
	if (pos == -1)
	{
		printf("不存在该人\n");
	}
	else
	{
		for (int i = pos;i <p->size;i++)
		{
			p->data[i] = p->data[i + 1];
		}
		p->size--;
		printf("删除完毕\n");
	}
}

void searchcontact(const contact* p)
{
	char name[NAME_MAX];
	printf("请输入要查找的姓名\n");
	scanf("%s", name);
	int pos = findcontact(p, name);
	if (pos == -1)
	{
		printf("找不到该人\n");
	}
	else
	{
		printf("姓名:%s\n", p->data[pos].name);
		printf("年龄:%d\n", p->data[pos].age);
		printf("性别:%s\n", p->data[pos].sex);
		printf("地址:%s\n", p->data[pos].dizhi);
		printf("电话:%s\n", p->data[pos].tem);
	}
}

void modifycontact(contact* p)
{
	printf("请输入要修改人的姓名\n");
	char name[NAME_MAX];
	scanf("%s", name);
	int pos = findcontact(p, name);
	if (pos == -1) printf("没有找到\n");
	else
	{
		printf("请修改姓名:\n");
		scanf("%s", p->data[pos].name);
		printf("请修改年龄:\n");
		scanf("%d", &p->data[pos].age);
		printf("请修改性别:\n");
		scanf("%s", p->data[pos].sex);
		printf("请修改地址:\n");
		scanf("%s", p->data[pos].dizhi);
		printf("请修改电话:\n");
		scanf("%s", p->data[pos].tem);
	}
}

void printfcontact(contact* p)
{
	for (int i = 0;i < p->size;i++)
	{
		printf("% -20s % -5s % -5s % -10s % -12s\n", "姓名", "年龄", "性别", "地址", "电话");
	printf("% -20s % -5d % -5s % -10s % -12s\n", p->data[i].name, p->data[i].age, p->data[i].sex,
		p->data[i].dizhi, p->data[i].tem);
	printf("\n");
	}
}

void sortcontact(contact* p)
{
	for (int i = 0;i < p->size - 1;i++)
	{
		for (int j = 0;j < p->size - 1 - i;j++)
		{
			if (strcmp(p->data[j].name, p->data[j + 1].name)>0)
			{
				people tem;//
				tem = p->data[j];
				p->data[j] = p->data[j + 1];//444 p->data[j].name!=tem
				p->data[j] = tem;
			}
		}
	}
	printf("排序完成!\n");
}


好久没学习了,,,,

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值