通讯录 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");
}
好久没学习了,,,,