文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

C语言实现通讯录的代码怎么写

2023-06-22 06:29

关注

这期内容当中小编将会给大家带来有关C语言实现通讯录的代码怎么写,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

(一)实现思路

1.通讯录功能

添加好友,删除好友,查找好友,修改好友信息,对好友进行排序

2.模块化实现各方面的功能

a. test.c

测试通讯录功能

b. Contact.c

实现通讯录功能

c. Contact.h

包含通讯录实现的头文件

3.代码实现

(二)源代码

A.test.c

#define _CRT_SECURE_NO_WARNINGS 1#include <stdio.h>#include <stdlib.h>#include <string.h>#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("***  7.Help        8.About0 ***\n");printf("***  0.Exit                 ***\n");printf("*******************************\n");}  int main(){ int input = 0;//创建通讯录int size = 0;struct Contact con;//一个结构体里包含1000个人的信息和size;//size表示的是该通讯录里现在的好友数//初始化通讯录InitContact(&con);//使size的初始值,以及好友信息初始化为0;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("退出通讯录!");break; //通讯录的使用以及帮助case Help:HelpContact();break; //关于通讯录case About:AboutContact();break; //选择错误default:printf("选择错误!");break;} } while (input);return 0;}

B.Contact.h

#define _CRT_SECURE_NO_WARNINGS 1#define Max 1000#define Max_name 20#define Max_sex 5#define Max_tele 12#define Max_addr 30 enum Option{Exit,Add,Del,Search,Modify,Show,Sort,Help,About };  //创建一个结构体来存放通讯录中要存放的信息struct PeoInfo{char name[Max_name];int age;char sex[Max_sex];char tele[Max_tele];char addr[Max_addr];}; //通讯录类型struct Contact{struct PeoInfo data[Max];//存放一个信息,包括好友姓名,年龄,性别,电话,地址int size;//记录当前已经有的元素个数//存入一个好友,size加1,表示通讯录人数增加一个};  //声明函数//1.对通讯录进行初始化void InitContact(struct Contact* ps); //增加好友信息void AddContact(struct Contact* ps); //删除好友void DelContact(struct Contact* ps); //查找指定姓名的好友void SearchContact(struct Contact* ps); //显示好友信息void ShowContact(const struct Contact* ps); //修改好友信息void ModifyContact( struct Contact* ps); //按名字首字母对通讯录的好友进行排序void SortContact( struct Contact* ps); //帮助使用通讯录void HelpContact(); //关于通讯录void AboutContact();

C.Contact.c

#define _CRT_SECURE_NO_WARNINGS 1 #include "contact.h"#include <stdio.h>#include <stdlib.h>#include <string.h> //初始化通讯录void InitContact(struct Contact* ps){memset(ps->data, 0, sizeof(ps->data));ps->size = 0;//设置通讯录最初只有0个元素}  //帮助使用通讯录void HelpContact(){printf("各按键的使用:\n");printf("1.添加好友\n");    printf("2.删除好友\n");printf("3.查找好友信息\n");printf("4.修改好友信息\n");printf("5.显示好友信息\n");printf("6.对好友进行排序\n");printf("7.帮助使用通讯录\n");printf("8.关于通讯录\n");printf("谢谢使用通讯录!\n"); } //关于通讯录void AboutContact(){printf("通讯录一般指在日常生活中用笔记录,也在手机,电脑,电子字典等电子产品中拥有这个功能。\n");}  //增加好友的电话,信息void AddContact(struct Contact* ps){if (ps->size == Max){printf("通讯录已满,无法增加!\n");}else{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++;//添加成功一个1好友,size加1,;printf("添加成功!\n");} }  //在删除,查找,修改的函数中均涉及查找到该好友才能进行//为了避免冗余,我们把查找的这个环节从函数中抽离出来//在函数中直接使用,就不会显得重复 static int Find_by_name(struct Contact* ps, char name[Max_name]){int i;for (i = 0; i < ps->size; i++){//将要查找的好友姓名与通讯录中的好友进行比较if (0 == strcmp(ps->data[i].name, name)){//若找到,返回其下标return i;}}//若都循环,比对完了以后还没找到就返回-1return -1;}  //删除好友信息void DelContact(struct Contact* ps){int  j;char name[Max_name];printf("请输入删除好友的名字:");scanf("%s", name);//1.查找要删除的人的位置int pos = Find_by_name(ps, name);//调用函数进行查找,若找到,返回下标,若没找到,返回-1;//2.删除if (pos==-1){printf("该好友不存在!\n");}else{//删除数据for (j = pos; j < ps->size - 1; j++){ps->data[j] = ps->data[j + 1];//删除数据后,后面的元素位置都改变,向前移动一个位置;}ps->size--;//删除一个好友,size-1.printf("删除成功!\n");}}  //查找指定好友信息void SearchContact(struct Contact* ps){char name[Max_name];printf("输入要查找的好友姓名:");scanf("%s", name);int pos = Find_by_name(ps, name);if (pos ==-1){printf("该好友不存在!\n");}else{printf("%10s\t%4s\t%5s\t%12s\t%20s\n", "名字", "年龄", "性别", "电话", "地址");printf("%10s\t%4d\t%5s\t%12s\t%20s\n",ps->data[pos].name,ps->data[pos].age,ps->data[pos].sex,ps->data[pos].tele,ps->data[pos].addr);} } //修改好友信息void ModifyContact(struct Contact* ps){char name[Max_name];printf("请输入需要修改信息的好友姓名:");scanf("%s", name);int pos=Find_by_name(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);printf("修改成功!\n");} }  //显示出好友的基本信息void ShowContact(const struct Contact* ps){if (ps->size == 0){printf("通讯录为空!\n");}else{int i = 0;printf("%10s\t%4s\t%5s\t%12s\t%20s\n", "名字", "年龄", "性别", "电话", "地址");for (i = 0; i < ps->size; i++){printf("%10s\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 cmp_stu_by_name(const void* e1, const void* e2){return (strcmp(((struct Contact*)e1)->data->name, ((struct Contact*)e2)->data->name));}  //我们用qsort()函数对我们的好友按照名字首字母进行排序void SortContact( struct Contact* ps){qsort(ps->data, ps->size, sizeof(ps->data[0]), cmp_stu_by_name);printf("%10s\t%4s\t%5s\t%12s\t%20s\n", "名字", "年龄", "性别", "电话", "地址");int i;for (i = 0; i < ps->size; i++){printf("%10s\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);}}

上述就是小编为大家分享的C语言实现通讯录的代码怎么写了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯