用c语言编辑一个通讯录,C语言实现一个通讯录

实现一个通讯录,通讯录可以用来存储1000个人的信息,每个人的信息包括:

姓名、性别、年龄、电话、住址

提供方法:

1. 添加联系人信息

2. 删除指定联系人信息

3. 查找指定联系人信息

4. 修改指定联系人信息

5. 显示所有联系人信息

6.  清空所有联系人

7. 以名字排序所有联系人

没有开辟动态内存的方法:

头文件:test.h

#ifndef __CONTACT

#define __CONTACT

#define _CRT_SECURE_NO_WARNINGS 1

#include

#include

#include

#include

#define N 1000

typedef struct contact

{

char name[30];

char gender[10];

int age;

int telephone;

char address[100];

};//结构体没有定义变量属于声明一个结构体类型

void meau();

void show(struct contact *p, int len);//struct contact *p:结构体指针指向这个结构体, int len:结构体数组的长度

void Add_linkman(struct contact *p, int len,int flag);

int Delete_linkman(struct contact *p, int d_number, int len);//int d_number选择要删除第几个结构体的内容

void Find_member(struct contact *p, int d_number, int len);//int d_number表示要查找的第几个结构体的内容(即联系人的信息)

void empty(struct contact *p);

void Modify(struct contact *p, int M_member);//int M_member:要修改的第几个联系人

int cmp(const void *a, const void *b);//qsort里面的比较函数定义任意类型

void sort(struct contact *p, int len);//根据联系人的名字进行排序

#endif//条件编译

contact.c文件

#include"test.h"

void meau()

{

printf(" *******************************************\n");

printf(" *******************************************\n");

printf(" ##############My address book##############\n");

printf(" *1-Add 2-Delete 3-Find *\n");

printf(" *4-Empty 5-Modify 6-Sort *\n");

printf(" *0-Exit 7-Show *\n");

printf(" *******************************************\n");

printf(" *******************************************\n");

}

void show(struct contact *p, int len)

{

assert(p);

int i = 0;

for (i = 0; i < len; i++)

{

printf("name:%s gender:%s age:%d telephone:%d address:%s", \

p[i].name, p[i].gender, p[i].age, p[i].telephone, p[i].address);

printf("\n");

}

}

void Add_linkman(struct contact *p, int len,int flag)

{

assert(p);

int i = 0;

for (i = flag; i < len; i++)

{

printf("请输入姓名:");

scanf("%s", &p[i].name);

printf("请输入姓别:");

scanf("%s", &p[i].gender);

printf("请输入年龄:");

scanf("%d", &p[i].age);

printf("请输入电话:");

scanf("%d", &p[i].telephone);

printf("请输入地址:");

scanf("%s", &p[i].address);

}

}

int Delete_linkman(struct contact *p, int d_number, int len)

{

assert(p);

int i = 0;

for (i = d_number - 1; i < len - 1; i++)

{

p[i] = p[i + 1];

}

}

void Find_member(struct contact *p, int d_number, int len)

{

assert(p);

if (d_number - 1 >= 0 || d_number - 1

{

printf("name:%s gender:%s age:%d telephone:%d address:%s", \

p[d_number].name, p[d_number].gender, p[d_number].age, p[d_number].telephone, p[d_number].address);

printf("\n");

}

else

{

printf("不存在该联系人:");

return;

}

}

void empty(struct contact *p)

{

assert(p);

int i = 0;

for (i = 0; i <1000; i++)

{

memset(p+i, 0, sizeof(struct contact));

}

}

void Modify(struct contact *p, int M_member)

{

assert(p);

printf("修改之前联系人的信息为:");

printf("\n");

printf("name:%s gender:%s age:%d telephone:%d address:%s", \

p[M_member - 1].name, p[M_member - 1].gender, p[M_member - 1].age, p[M_member - 1].telephone, p[M_member - 1].address);

printf("\n");

printf("请输入要修改的信息:");

printf("请输入姓名:");

scanf("%s", &p[M_member - 1].name);

printf("请输入姓别:");

scanf("%s", &p[M_member - 1].gender);

printf("请输入年龄:");

scanf("%d", &p[M_member - 1].age);

printf("请输入电话:");

scanf("%d", &p[M_member - 1].telephone);

printf("请输入地址:");

scanf("%s", &p[M_member - 1].address);

}

int cmp(const void *a, const void *b)

{

struct contact *aa = (struct contact *)a;

struct contact *bb = (struct contact *)b;

if (aa->name != bb->name)

return(strcmp((aa->name), (bb->name)));

}

void sort(struct contact *p, int len)

{

assert(p);

qsort(p, len, sizeof(struct contact), cmp);

}

test.c文件:

#include"test.h"

int main()

{

int num = 0;

struct contact student[N];

int len = 0;

int flag = 0;//定义一个标志位来结构体数组中每个结构体的位置

int total = N;

int delete_number = 0;

meau();

while (1)

{

printf("请输入数字进行选择:");

scanf("%d", &num);

switch (num)

{

case 1:{

printf("请添加len个学生的信息:");

scanf("%d", &len);

Add_linkman(student,len+flag,flag);

flag=flag+len;

}break;

case 2:{

printf("请输入要删除的第i个学生的信息:");

scanf("%d", &delete_number);

Delete_linkman(student, delete_number, len+flag);

flag = flag - 1;

}break;

case 3:{

int Find_number = 0;

printf("请输入要查找的第i个学生的信息:");

scanf("%d", &Find_number);

Find_member(student, delete_number, len+flag);

}break;

case 4:{

printf("清空所有联系人:");

empty(student);

}break;

case 5:{

printf("请输入要修改的的第i个学生的信息:");

int M_member = 0;

scanf("%d", &M_member);

Modify(student, M_member);

}break;

case 6:{

printf("根据名字排序所有联系人:\n");

sort(student, len+flag);

}break;

case 7:{

printf("打印所有联系人的信息:\n");

show(student, flag);

}break;

case 0:{

exit(1);

}

default:printf("enter error data!!!");

}

}

system("pause");

return 0;

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C语言课程设计任务书(4) 一、题目:通讯录管理 二、目的与要求 1. 目的: (1)基本掌握面向过程程序设计的基本思路和方法; (2)达到熟练掌握C语言的基本知识和技能; (3)能够利用所学的基本知识和技能,解决简单的程序设计问题 2. 要求 基本要求: 1.         要求利用C语言面向过程的编程思想来完成系统的设计; 2.       突出C语言的函数特征,以多个函数实现一个子功能; 3.         画出功能模块图; 4.         具有清晰的程序流程图和数据结构的详细定义; 5.       熟练掌握C语言对文件的各种操作。 创新要求: 在基本要求达到后,可进行创新设计,如系统用户功能控制,对管理员级和一般级别的用户系统功能操作不同 三、信息描述 有关该系统基本信息的描述,如:姓名、电话、城市和邮编等。 四、功能描述 1.       名单基本信息(姓名,城市,电话,邮编等)的录入,并存放在文件当中。 2.       基本信息的查询与修改。 3.       记录的添加和删除。 4.       对同一类型记录的查找:如查找同一城市的记录或同一省份的记录。 五、解决方案 1.       分析程序的功能要求,划分程序功能模块。 2.       画出系统流程图。 3.       代码的编写。定义数据结构和各个功能子函数。 4.       程序的功能调试。 5.       完成系统总结报告以及使用说明书 六、进度安排 此次课程设计时间为一周或两周,分四个阶段完成: 1.       分析设计阶段。指导教师应积极引导学生自主学习和钻研问题,明确设计要求,找出实现方法,按照需求分析、总体设计、详细设计这几个步骤进行。 2.       编码调试阶段:根据设计分析方案编写C代码,然后调试该代码,实现课题要求的功能。 3.       总结报告阶段:总结设计工作,写出课程设计说明书,要求学生写出需求分析、总体设计、详细设计、编码、测试的步骤和内容。 4.       考核阶段。 七、撰写课程设计报告或课程设计总结 课程设计报告要求: 总结报告包括需求分析、总体设计、详细设计、编码(详细写出编程步骤)、测试的步骤和内容、课程设计总结、参考资料等,不符合以上要求者,则本次设计以不及格记。 八、参考资料  《C语言程序设计教程》   网上相关资料(....略)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值