我的编程空间,编程开发者的网络收藏夹
学习永远不晚

C语言如何实现通讯录系统程序

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

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

C语言如何实现通讯录系统程序

本文小编为大家详细介绍“C语言如何实现通讯录系统程序”,内容详细,步骤清晰,细节处理妥当,希望这篇“C语言如何实现通讯录系统程序”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

前言

利用链表增、删、改、查功能以及文件来完成通讯录系统。通讯录中包含联系人的基本信息:姓名、联系电话、家庭住址以及电子邮件。

以下是设计该系统的步骤:

导出通讯录系统的功能:

(构建一个通讯录结构体)

#include<stdio.h>#include<stdlib.h>#include<string.h>#include<conio.h>  typedef struct record {    char name[30];    char phonenumber[11];    char address[3][30]; //定义一维 0-省 1-市 2-街道    char email[6];    struct record *next;} record;

声明用到的函数,不妨设置个密码,并设计出通讯录功能的主页面

void mainmenu();//声明通讯录主菜单 void alterstring(record *head);  void browsemenu(record *head, const int *total);//浏览通讯录主菜单 record *newrecord(record *head, int *total);//添加联系人信息 record *deleterecord(record *head,int *total);//删除联系人信息 record *modifyrecord(record *head);//修改联系人信息 record *searchrecord(record *head, int onlyonerecord) ;//查找联系人信息 record *importrecords(record *head, int *total);//导入联系人信息 record *exportrecords(record *head);//导出联系人信息     int main() {    char mima[10]={0};    int i=0;    printf("请输入密码:\n");    for(i=0;i<3;i++)    {        scanf("%s",mima);        if(strcmp(mima,"123456")==0)        {            printf("登录成功,亲爱的小猪崽!\n");            break;        }        else        {            printf("密码错误,笨熊!请重新输入密码:\n");        }    }    if(3==i)    {        printf("登录失败!老笨熊!!!\n");        exit(1);    }    system("pause");    int total = 0, choice;    record *head = NULL;    printf("\n\t\t\t            欢迎使用通讯录系统!\n");    printf("\n\t\t\t********************************************\n");    do     {        mainmenu();        scanf("%d", &choice);        system("cls");        switch (choice)         {            case 0:                break;            case 1:                browsemenu(head, &total);                break;            case 2:                head = newrecord(head, &total);                 break;            case 3:                head = deleterecord(head,&total);                break;            case 4:                head = modifyrecord(head);                break;            case 5:                searchrecord(head,0);                break;            case 6:                head = importrecords(head,&total);                break;            case 7:                exportrecords(head);                break;            default:                printf("\n\n**对不起,输入错误,请输入0~7!!!\n");        };    }     while (choice != 0);    return 0;}  void mainmenu() {    printf("\n");    printf("\n\t\t\t****************1.浏览通讯录****************\n");    printf("\n\t\t\t**************2.增加联系人信息**************\n");    printf("\n\t\t\t**************3.删除联系人信息**************\n");    printf("\n\t\t\t**************4.修改联系人信息**************\n");    printf("\n\t\t\t**************5.查找联系人信息**************\n");    printf("\n\t\t\t*************6.从文件中导入记录*************\n");    printf("\n\t\t\t*************7.从记录导出到文件*************\n");    printf("\n\t\t\t********************0.退出******************\n");    printf("\n\t\t\t********************************************\n");    printf("\n\t\t\t请输入0~7选择功能 :");}

以下为本程序亮点,就是所谓的增、删、改、查小牛功能:

 void alterstring(record *head) {    int m;    record *p1 = head;    while (p1 != NULL)     {        for (m = 0; m < 30; m++)         {            if (*((p1->name) + m) == '\n')             {                *((p1->name) + m) = '\0';            }        }        for (m = 0; m < 11; m++)         {            if (*((p1->phonenumber) + m) == '\n')             {                *((p1->phonenumber) + m) = '\0';            }        }        for (m = 0; m < 30; m++)         {            if (*((p1->address[0]) + m) == '\n')            {                *((p1->address[0]) + m) = '\0';            }        }        for (m = 0; m < 30; m++)         {            if (*((p1->address[1]) + m) == '\n')             {                *((p1->address[1]) + m) = '\0';            }        }        for (m = 0; m < 30; m++)         {            if (*((p1->address[2]) + m) == '\n')             {                *((p1->address[2]) + m) = '\0';            }        }        for (m = 0; m < 6; m++)         {            if (*((p1->email) + m) == '\n')             {                *((p1->email) + m) = '\0';            }        }        p1 = p1->next;    }}  record *newrecord(record *head, int *total) //链表首地址,总数地址 {    int i = *total;    char inputchar;    record *p = head, *input = (record *) malloc(sizeof(record));    printf("\n**请输入联系人信息\n");        if (*total)     {        printf("**共有 %d 个联系人信息\n\n", *total);    }    do     {        //输入联系人信息         printf("请输入第%d个联系人的名字:", i + 1);        fflush(stdin);//清理标准输入流,把多余未被保存的数据丢掉         fgets(input->name, 31, stdin);//输入长度为31的字符串         printf("请输入第%d个联系人的联系方式:", i + 1);        fflush(stdin);        fgets(input->phonenumber,31, stdin);        printf("请输入第%d个联系人的家庭地址:\n", i + 1);        printf("*请输入第%d个联系人所在省份:", i + 1);        fflush(stdin);        fgets(input->address[0], 31, stdin);        printf("*请输入第%d个联系人所在城市:", i + 1);        fflush(stdin);        fgets(input->address[1], 31, stdin);        printf("*请输入第%d个联系人所在街道:", i + 1);        fflush(stdin);        fgets(input->address[2], 31, stdin);        printf("请输入第%d个联系人的电子邮件:", i + 1);        fflush(stdin);        fgets(input->email, 7, stdin);        input->next = NULL; //插入时放至链表的最后         //插入数据,分为首数据和非首数据        if (head == NULL)         {            head = input;            p = input;        }         else         {            while (p->next != NULL)             {                p = p->next;            }            p->next = input;        }                  (*total)++;//计数-联系人的总人数         printf("\n**是否继续?(Y/N):");        scanf(" %c", &inputchar);                if (inputchar=='Y' || inputchar=='y')        {            input = (record *) malloc(sizeof(record));//创建新的空间             i++;        }         else         {            break;        }    }     while (1);    //按回车键跳转     alterstring(head);    return head; }  //打印全部联系人信息 void browsemenu(record *head, const int *total) {    int page = 1, firstindex = 0, i, pageamount = *total / 10 + 1;//定义联系人为一页     record *p = head;    do     {        system("cls");                 if (page > pageamount)         {            printf("**对不起,页数的最大值为%d\n", pageamount);        }         else if (page < 0)         {            printf("**对不起,输入的数字必须为正数\n");        }         else         {            //处理分页,十个联系人一页             firstindex = 10 * (page - 1);            printf("NO.\t姓名\t联系电话\t省\t市\t街道\t电子邮件\t\n");            //处理前置数据            p = head;            for (i = 0; i < firstindex; ++i)             {                p = p->next;            }            i = 0;            //输出数据            while (p!=NULL && i<10)             {                 i++;                printf("NO.%d\t%s\t%s\t\t%s\t%s\t%s\t%s\t\n", i+firstindex,p->name, p->phonenumber, p->address[0], p->address[1],                       p->address[2],                       p->email);                p = p->next;            }            printf("** Page %d (共 %d 页)\n ", page, pageamount);        }        printf("** 请输入跳转页面(按0返回通讯录主菜单):");        scanf("%d", &page);    }     while (page);}  record *deleterecord(record *head,int *total) {    record *p1 = head, *p2,*searchrestlt;    searchrestlt = searchrecord(head, 1);    while (p1 != NULL && p1 != searchrestlt)     {        p2 = p1;         //p2的上一个节点        p1 = p1->next;   //p1的下一个节点    }    if (p1 == head)     {        head = p1->next;        free(p1);        (*total)--;         printf("\n**删除成功!\n");    }     else if (p1 != NULL)     {        p2->next = p1->next;        free(p1);        (*total)--;        printf("\n* *删除成功!\n");    }     else     {        printf("\n**对不起,没有找到该联系人!\n");    }    return head;} //输出联系人信息 void printonerecord(record *p) {    printf("姓名:%s\t联系电话:%s\t省:%s\t市:%s\t街道::%s\t电子邮件:%s\t\n", p->name, p->phonenumber,           p->address[0], p->address[1], p->address[2], p->email);}  record *modifyrecord(record *head){    record *p1 = head, *p2,*searchrestlt,*input = (record *) malloc(sizeof(record));    //返回需要修改的数组地址    searchrestlt = searchrecord(head, 1);    if (!searchrestlt)    {        return head;    }    //输入联系人信息     printf("\n请输入修改的联系人姓名:");    fflush(stdin);    fgets(input->name, 30 + 1, stdin);    printf("请输入修改的联系人的联系电话:");    fflush(stdin);    fgets(input->phonenumber,30 + 1, stdin);    printf("请输入修改的联系人的地址:\n");    printf("请输入修改的联系人的省份:");    fflush(stdin);    fgets(input->address[0], 30 + 1, stdin);    printf("请输入修改的联系人的城市:");    fflush(stdin);    fgets(input->address[1], 30 + 1, stdin);    printf("请输入修改的联系人的街道:");    fflush(stdin);    fgets(input->address[2], 30 + 1, stdin);    printf("请输入修改的联系人的电子邮件:");    fflush(stdin);    fgets(input->email, 7, stdin);    //插入时放于链表的最后    input->next = NULL;    while (p1 != NULL && p1 != searchrestlt)     {        p2 = p1;         //p2上一个节点        p1 = p1->next;   //p1下一个节点    }    if (p1 == head)     {        head = input;        input->next = p1->next;        free(p1);          printf("\n**修改成功!\n");    }     else if (p1 != NULL)     {        p2->next = input;        input->next = p1->next;        free(p1);        printf("\n**修改成功!\n");    }     else     {        printf("\n-- Do not find this id!\n");    }    alterstring(head);    return head;}  record *searchrecord(record *head, int onlyonerecord) {    int amount = 0, i = 0, choice = 0; //i,p1循环变量    char input[30];    record *p1 = head, *results[100] = {NULL}; //result是record类型的指针数组    printf("\n查找联系人:");    setbuf(stdin, NULL);//关闭输入缓冲区     fgets(input, 30 + 1, stdin);    for (i = 0; i < 30; ++i)     {        if (*((input) + i) == '\n')         {            *((input) + i) = '\0';        }    }    //遍历搜索    while (p1 != NULL)     {        if (strstr(p1->name, input) ||   //strstr()判断是否为子串            strstr(p1->phonenumber, input) ||            strstr(p1->address[0], input) ||            strstr(p1->address[1], input) ||            strstr(p1->address[2], input) ||            strstr(p1->email, input)) {            results[amount] = p1;            amount++;        }        p1 = p1->next;    }     //若有同名同信息,根据编号选择联系人     if (amount > 1)     {        printf("\n查找结果:\n");        for (i = 0; i < amount; i++)         {            printf("NO.%d\t", i + 1);            printonerecord(results[i]);        }        if (!onlyonerecord)         {            return NULL; //如果不需要去重,则返回NULL        }        printf("\n**请输入你要删除的联系人编号: ");        scanf("%d", &choice);        //若输入联系人编号不正确,默认删除第一位联系人         if (choice-1>amount || choice<0)         {            printf("\n**输入错误(默认删除第一位联系人)");            return results[0];        }        return results[choice - 1];    }     else if (!amount)     {        printf("\n**对不起,没有找到该联系人!");        return NULL;    }     else     {        printf("\n** 查找结果:\n");        printonerecord(results[0]);        return results[0];    }}

最后保存至文件,以便下次查看。

 record *importrecords(record *head, int *total) {    int i = *total,m=3;    FILE *fpRead;    record *p = head, *input;    fpRead = fopen("stu.txt","r");    if(fpRead==NULL)    {        printf("can't open file\n");        return 0;    }    do     {        //输入数据(联系人信息)         input = (record *) malloc(sizeof(record));        fread(input, sizeof(struct record),1,fpRead);        input->next = NULL; //插入时放于链表的最后         //插入数据,分为首数据和非首数据        if (head == NULL)         {            head = input;            p = input;        }         else         {            while (p->next != NULL)             {                p = p->next;            }            p->next = input;        }        (*total)++;//计数         m--;    }     while (m);    return head;} record *exportrecords(record *head){    FILE *fp;    struct record *p=head;    if((fp=fopen("stu.txt","wb"))==NULL)    {        printf("Fail to open the stu.txt!\n");        exit(0);    }    while(p != NULL)    {        fwrite(p, sizeof(struct record),1,fp);        p=p->next;    }    fclose(fp);    printf("您已成功保存!\n");    return 0;}

读到这里,这篇“C语言如何实现通讯录系统程序”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网行业资讯频道。

免责声明:

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

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

C语言如何实现通讯录系统程序

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

C语言如何实现通讯录系统程序

本文小编为大家详细介绍“C语言如何实现通讯录系统程序”,内容详细,步骤清晰,细节处理妥当,希望这篇“C语言如何实现通讯录系统程序”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。前言利用链表增、删、改、查功能以及文件
2023-07-02

C语言模拟实现通讯录程序过程

这篇文章主要介绍了C语言模拟实现通讯录程序过程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
2023-02-14

C++如何实现通讯录系统

本篇内容介绍了“C++如何实现通讯录系统”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!制作一个具有添加联系人、删除联系人、修改联系人等功能的
2023-07-02

C语言单链表如何实现通讯录管理系统

这篇文章将为大家详细讲解有关C语言单链表如何实现通讯录管理系统,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。通讯录管理系统保存人的信息有: 名字 name电话 telephone性别 sex年
2023-06-15

C语言开发实现通讯录管理系统

这篇文章主要为大家详细介绍了C语言开发实现通讯录管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
2022-11-13

C语言中怎么实现一个通讯录系统

C语言中怎么实现一个通讯录系统,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。全部代码如下所示:#include #include usi
2023-06-20

C语言如何实现通讯录小项目

这篇文章主要介绍了C语言如何实现通讯录小项目,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。本文实例为大家分享了C语言实现通讯录小项目的具体代码,供大家参考,具体内容如下编写程
2023-06-15

怎么用C语言实现简单通讯录管理系统

本篇内容主要讲解“怎么用C语言实现简单通讯录管理系统”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用C语言实现简单通讯录管理系统”吧!C语言实现的通讯录管理系统,供大家参考,具体内容如下设计
2023-06-20

C语言怎么实现简单的通讯录管理系统

下面是一个使用C语言实现简单通讯录管理系统的示例代码:#include #include #define MAX_CONTACTS 100#define MAX_NAME_LENGTH 50#d
C语言怎么实现简单的通讯录管理系统
2024-03-08

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录