C语言实现简单的电子通讯录

**制作一个电子通讯录,通过该通讯录能录入好友ID号、姓名(英文)、手
机号码,家庭住址,公司电话。**
原理:分成5个模块,将模块功能实现写入头文件中。主函数部分代码:
显示函数部分,在Markdown里对不齐,意思就这样,将就一下=。=
这里写图片描述
这里写图片描述

/*******************************************************************
需求:制作一个电子通讯录,通过该通讯录能录入好友ID号、姓名(英文)、手
机号码,家庭住址,公司电话。
模块:主界面:主要显示软件功能,A)添加好友信息 B)列表好友信息。(包含排序功能) C)搜索好友 D)删除好友A)用户输入INSERT命令后,让用户输入好友信息。添加成功或失败都需提示B)用户输入DISPLAY命令后,好友信息升序排列C)用户输入SEARCH命令后,让用户输入将要搜索好友姓名查询。如果未搜索到请友好提示。如果搜索到,显示处该好友信息D)用户输入DELETE命令后,让用户输入将要删除好友姓名删除,如果存在同名的多个好友,则列表出,所有同名的好友信息,让用户通过输入ID号删除提示用户删除成功。
**********************************************************************/
#include "head.h"int main ()
{int Function;int i = 0;char Name[N];int cho;PNode head_node = (PNode) malloc(sizeof(Node)/sizeof(char));if (NULL == head_node){return MALLOC_ERROR;}head_node->next = NULL;while (1){Interface_Display ();scanf ("%d", &Function);switch (Function)               // 功能选择{case 1:                     // 添加好友{Function = 0;Add_Friend (head_node, i++);int j;printf ("\t正在添加\n");printf ("\t请稍候");fflush (stdout);        // 强制刷新缓存,输出显示for (j = 0; j < 3; j++){sleep (1);          // Linux 使用sleep,参数为秒printf (".");fflush (stdout);    // 强制刷新缓存,输出显示}printf ("\n");printf ("\t添加成功!\n");printf ("\t返回主菜单请输入1:");scanf ("%d", &cho);if (1 == cho){break;}else{printf ("\t对不起!您的输入有误!请重新输入:");scanf ("%d", &cho);break;}break;}           case 2:                 // 显示好友信息{system ("clear");printf ("\t*********好友信息********\n");printf ("\n");Friend_Information (head_node);Function = 0;printf ("\t返回主菜单请输入1:");scanf ("%d", &cho);if (1 == cho){break;}else{printf ("\t对不起!您的输入有误!请重新输入:");scanf ("%d", &cho);break;}break;}case 3:                 // 查找好友{system ("clear");printf ("\t*************查找好友*************\n");printf ("\t请输入您要查找的好友姓名:");scanf  ("%s", Name);printf ("\n");int j;          printf ("\t正在查找\n");printf ("\t请稍候");fflush (stdout);        // 强制刷新缓存,输出显示for (j = 0; j < 3; j++){sleep (1);          // Linux 使用sleep,参数为秒printf (".");fflush (stdout);    // 强制刷新缓存,输出显示}printf ("\n");Search_Friend (head_node, Name);printf ("\t返回主菜单请输入1:");scanf ("%d", &cho);if (1 == cho){break;}else{printf ("\t对不起!您的输入有误!请重新输入:");scanf ("%d", &cho);break;}break;}case 4:                     //删除好友{system ("clear");printf ("\t*************删除好友*************\n");printf ("\t请输入要删除好友的姓名:");scanf  ("%s", Name);printf ("\n");Delete_Friend (head_node, Name);printf ("\t返回主菜单请输入1:");scanf ("%d", &cho);if (1 == cho){break;}else{printf ("\t对不起!您的输入有误!请重新输入:");scanf ("%d", &cho);break;}break;}   case 5:                     //退出通讯录{Function = 0;system ("clear");exit (0);}default:                    //输入有误{Function = 0;printf ("\t对不起!您的输入有误!请重新输入:");scanf ("%d", &Function);break;}           }       }   return 0;
}

head.h部分:

#ifndef HEAD_H_
#define HEAD_H_#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>             // sleep函数头文件#define uint unsigned int
#define OK            0
#define ERROR         -1
#define MALLOC_ERROR  -2
#define N             20 typedef int ElementType;
typedef struct node
{ElementType ID;             // ID号char Name [N];              // 姓名char Mobile_Phone [N];      // 手机号码char Home_Address [N];      // 家庭住址char Company_Tell [N];      // 公司电话struct node* next;          // 节点指针
}Node;
typedef Node* PNode;            //重命名节点指针类型//显示操作界面
int Interface_Display ();//添加好友信息 (尾插法)
int Add_Friend (PNode head, ElementType num);//显示所有好友信息
int Friend_Information (PNode head);//查找好友
int Search_Friend (PNode head, char* Name);//删除好友
void Delete_Friend (PNode head, char* Name);#endif

head.c的代码:

#include "head.h"//显示操作界面
int Interface_Display ()
{system ("clear");printf ("\t************************************** \n");printf ("\t~          欢迎使用通讯录               ~\n");printf ("\t~                                     ~\n");printf ("\t~      1 >>>>>>>> 添加好友信息          ~\n");printf ("\t~      2 >>>>>>>> 列表好友信息          ~\n");printf ("\t~      3 >>>>>>>> 搜索好友             ~\n");printf ("\t~      4 >>>>>>>> 删除好友             ~\n");printf ("\t~      5 >>>>>>>> 退出                ~\n");printf ("\t~                                     ~\n");printf ("\t~                                     ~\n");printf ("\t~                       作者:believe  ~\n");printf ("\t~*************************************~\n");printf ("                                         \n");printf ("                                         \n");printf ("\t请输入对应数字选择相应功能:");
}//添加好友信息 (尾插法)
int Add_Friend (PNode head, ElementType num)
{if (NULL == head){return ERROR;}//创建一个新的结点PNode p = (PNode) malloc(sizeof(Node)/sizeof(char));if (NULL == p){return MALLOC_ERROR;}//将新数据赋给新结点system("clear");    printf ("\t*************添加好友***************\n");p->ID = num;printf ("\t好友的ID为:%d\n", p->ID);printf ("\n");printf ("\t请输入好友的名字:");scanf  ("%s", p->Name);printf ("\n");printf ("\t请输入好友的手机号:");scanf  ("%s", p->Mobile_Phone);printf ("\n");printf ("\t请输入好友的家庭住址:");scanf  ("%s", p->Home_Address);printf ("\n");printf ("\t请输入好友的公司电话:");scanf  ("%s", p->Company_Tell);printf ("\n");p->next = NULL;//找到最后一个结点PNode Ptmp;                 //将头结点地址给临时指针PtmpPtmp = head;while (Ptmp->next){Ptmp = Ptmp->next;}Ptmp->next = p;return OK;
}//显示所有好友信息
int Friend_Information (PNode head)
{if (NULL == head){return ERROR;}PNode p = head->next;printf ("\tID\t姓名\t\t手机号\t\t住址\t\t\t公司电话\n");while (p){printf ("\t%d\t%s\t\t%s\t\t%s\t\t\t%s\n", p->ID,p->Name, p->Mobile_Phone, p->Home_Address, p->Company_Tell);p = p->next;}putchar('\n');return OK;
}//查找好友
int Search_Friend (PNode head, char* Name)      //通过名字查找好友
{PNode p = head;PNode q = NULL;if ((NULL != p) && NULL != (p->next)){while (p->next) {q = p->next;if ((NULL != q) && 0 == (strcmp(q->Name, Name))){printf ("\t好友信息: \n\tID:%d\n\t姓名: %s\n\t手机号码: %s\n\t家庭地址:%s\n\t公司电话: %s\n", q->ID, q->Name, q->Mobile_Phone, q->Home_Address, q->Company_Tell);}else{printf ("\t对不起,您的通讯录没有该好友!\n");}p = p->next;}}/*  另一种做法if (NULL == head){return ERROR;}PNode p;int flag = 1;for (p = head->next; p != NULL; p = p->next){if (0 == strcmp(p->Name, Name)){flag = 0;printf ("\t好友信息:\n\tID: %d\n\t姓名: %s\n\t手机号码: %s\n\t家庭地址: %s\n\t公司电话: %s\n", p->ID, p->Name, p->Mobile_Phone, p->Home_Address, p->Company_Tell);}}fi (flag){printf ("\t对不起,您的通讯录没有该好友!\n");}putchar('\n');*/return OK;
}//删除好友
void Delete_Friend (PNode head, char* Name)
{PNode p = head;PNode q = NULL;while (NULL != p && NULL != (p->next)){q = p->next;if (NULL != q && 0 == strcmp(q->Name, Name)){p->next = q->next;free(q);int j;printf ("\t正在删除\n");printf ("\t请稍候");fflush (stdout);            //强制刷新缓存,输出显示for (j = 0; j < 3; j++){sleep (1);              //linux使用sleep,参数为秒printf (".");fflush(stdout);         //强制刷新缓存,输出显示}printf ("\n");printf ("\t该好友已成功删除!\n");}else if (NULL == q->next && 0 != strcmp(q->Name, Name)){printf ("\t您的通讯录没有该好友!\n");}p = p->next;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/448539.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Jackson使用:String 与对象互转、Jackson 从 json 字符串转换出对象

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 一、从json字符串转换出对象 Pager类&#xff1a; import com.fasterxml.jackson.annotation.JsonIgnoreProperties; JsonIgnoreProper…

13个好习惯 教你健康一整年

怎么在坐着上班时&#xff0c;练出紧实小腹&#xff1f;如何在酗咖啡的紧凑中&#xff0c;帮身体排毒&#xff1f;新年初始&#xff0c;《天下》介绍十三个小诀窍&#xff0c;让你轻松变健康。 一年初始&#xff0c;该如何规划最重要的“健康”&#xff1f;《天下》邀请专家&am…

结构体的传参理解成员的存储方式

结构体的成员变量在内存中存储的方式&#xff0c;决定于设定的内存对齐方式是几字节&#xff1a;gcc编译默认使用4字节对齐&#xff1a; 1 #include <stdio.h>2 3 typedef struct test_buf4 {5 int a;6 char c;7 char buf[8];8 char *str;9 10 }buf…

eclipse插件大全整理学习

Eclipse Web Tools Platform(WTP) 地址&#xff1a;http://download.eclipse.org/webtools/ WTP十分强大&#xff0c;支持HTML, JavaScript, XML, JSP&#xff0c;支持语法着色&#xff0c;代码提示&#xff0c;代码折叠等&#xff0c;以及其它一堆JavaEE相关的功能。Web开发必…

数据结构之顺序栈的一些基本操作

** 顺序栈可以用一个一维数组和一个记录栈顶位置的整形变量来实现&#xff0c;数组用于顺序存储栈中所有的数据元素&#xff0c;栈顶指针用于存储栈顶元素的位置。 ** 头文件&#xff08;Sqstack.h&#xff09;&#xff1a; #ifndef __SQSTACK_H__ #define __SQSTACK_H__#i…

网友力荐教子名言 只有50句却能改变儿女一生

从当今的家庭来看&#xff0c;大多数的家长把自己的一切希望寄托在孩子的身上&#xff0c;这个〝望子成龙〞或〝盼女成凤〞的希望能否成为现实&#xff0c;需要多方面的努力&#xff0c;而家庭是孩子的第一所〝学校〞&#xff0c; 父母是孩子的第一位〝老师〞&#xff0c;家庭…

guava 之 ImmutableMap 使用实例及好处

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 ImmutableMap 的作用就是&#xff1a;可以让java代码也能够创建一个对象常量映射&#xff0c;来保存一些常量映射的键值对。 分析以下情…

从事前端开发必须要了解的CSS原理(转)

一、浏览器的发展与CSS 网页浏览器主要通过 HTTP 协议连接网页服务器而取得网页&#xff0c; HTTP 容许网页浏览器送交资料到网页服务器并且获取网页。目前最常用的 HTTP 是 HTTP/1.1&#xff0c;这个协议在 RFC2616 中被完整定义。HTTP/1.1 有其一套 Internet Explorer 并不完…

oracle函数 MIN([distinct|all]x)

【功能】统计数据表选中行x列的最大值。 【参数】all表示对所有的值求最大值,distinct只对不同的值求最大值&#xff0c;默认为all 如果有参数distinct或all&#xff0c;需有空格与x(列)隔开。 【参数】x&#xff0c;可为数字、字符或日期型字段 【返回】对应x字段类型 注&…

数据结构之链式栈的一些基本操作

链式栈是一种数据存储结构&#xff0c;可以通过单链表的方式来实现&#xff0c;使用链式栈的优点在于它能够克服用数组实现的顺序栈空间利用率不高的特点&#xff0c;但是需要为每个栈元素分配额外的指针空间用来存放指针域。 头文件 LinkStack.h #ifndef __LINKSTACK_H__ #d…

做人做事的8大智慧

一、守拙的智慧&#xff1a;心头洞明&#xff0c;表面糊涂。 做人的最高境界&#xff0c;就是抱朴守拙。不张扬&#xff0c;平易近人&#xff0c;虽不高人一等&#xff0c;但更得众人的欢迎。社会是很现实的&#xff0c;人心更是难测的。当你聪明绝顶、锋芒毕露时&#xff0c;则…

@Test 运行 Method xxx should be void、Method xxx should have no parameters

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 Method test should have no parameters...java.lang.Exception: Method test should have no parameters ... 报错如上&#xff0…

TKmybatis和mybatisplus哪个好用

文档连接 &#xff1a;http://baomidou.oschina.io/mybatis-plus-doc/#/?id%E7%AE%80%E4%BB%8B https://gitee.com/hengboy/mybatis-enhance https://gitee.com/free/Mapper/wikis/1.3-spring-boot?sort_id208198 https://durcframework.gitee.io/fastmybatis/ 注&#xff1a…

物理内存不够用,临时增大Linux交换分区的方法

当系统的物理内存不够用的时候&#xff0c;就需要将物理内存中的一部分空间释放出来&#xff0c;以供当前运行的程序使用。那些被释放的空间可能来自一些很长时间没有什么 操作的程序&#xff0c;这些被释放的空间被临时保存到Swap空间中&#xff0c;等到那些程序要运行时&…

数据结构之顺序队列和链式队列常用的一些操作

顺序队列是队列的顺序存储结构&#xff0c;顺序队列实际上是运算受限的顺序表。和顺序表一样&#xff0c;顺序队列用一个向量空间来存放当前队列中的元素。由于队列的队头和队尾的位置是变化的&#xff0c;设置两个指针front和rear分别指示队头元素和队尾元素在向量空间中的位置…

33个训练大脑的小方法

已经步入经常忘事的年龄了。常常是提起一个人&#xff0c;形象都在脑海中&#xff0c;但就是说不出其姓名来&#xff0c;哪怕就在嘴边也说不出来。有时候遇到一个人&#xff0c;知道是熟悉的人&#xff0c;但就是想不起名字了&#xff0c;有时候弄得很尴尬。 书里说&#xff0c…

linux常用命令(4)

linux常用命令(4) --- Vim编辑器与Shell命令脚本 如何使用vim编辑器来编写文档、配置主机名称、网卡参数以及yum仓库&#xff1b;通过vim编辑器将Linux命令放入合适的逻辑测试语句&#xff08;if、for、while、case&#xff09;后最终写出简单使用的shell脚本;可以通过at命令或…

script 标签到底该放在哪里

一般script标签会被放在头部或尾部。头部就是<head>里面&#xff0c;尾部一般指<body>里。 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 将script放在<head>里&a…

栈在表达式计算过程中的应用

栈在表达式计算过程中的应用 &#xff1a;建立操作数栈和运算符栈。运算符有优先级。 规则&#xff1a; 自左至右扫描表达式&#xff0c;凡是遇到操作数一律进操作数栈。 当遇到运算符时&#xff0c;如果它的优先级比运算符栈栈顶元素的优先级高就进栈。反之&#xff0c;取出…

Python-02-基础知识

一、第一个Python程序 【第一步】新建一个hello.txt 【第二步】将后缀名txt改为py 【第三步】使用记事本编辑该文件 【第四步】在cmd中运行该文件 print("Hello World!") 强调&#xff1a;python解释器执行程序是解释执行&#xff0c;即打开文件读内容&#xff0c;因…