通讯录
来源:互联网 发布:直播点歌软件 编辑:程序博客网 时间:2024/05/21 17:19
/*******************************************************************
需求:制作一个电子通讯录,通过该通讯录能录入好友ID号、姓名(英文)、手
机号码,家庭住址,公司电话。
模块:
主界面:主要显示软件功能,A)添加好友信息 B)列表好友信息。(包含排序
功能) C)搜索好友 D)删除好友
A)用户输入INSERT命令后,让用户输入好友信息。添加成功或失败都需提示
B)用户输入DISPLAY命令后,好友信息升序排列
C)用户输入SEARCH命令后,让用户输入将要搜索好友姓名查询。如果未搜索
到请友好提示。如果搜索到,显示处该好友信息
D)用户输入DELETE命令后,让用户输入将要删除好友姓名删除,如果存在同
名的多个好友,则列表出,所有同名的好友信息,让用户通过输入ID号删除
main.c
需求:制作一个电子通讯录,通过该通讯录能录入好友ID号、姓名(英文)、手
机号码,家庭住址,公司电话。
模块:
主界面:主要显示软件功能,A)添加好友信息 B)列表好友信息。(包含排序
功能) C)搜索好友 D)删除好友
A)用户输入INSERT命令后,让用户输入好友信息。添加成功或失败都需提示
B)用户输入DISPLAY命令后,好友信息升序排列
C)用户输入SEARCH命令后,让用户输入将要搜索好友姓名查询。如果未搜索
到请友好提示。如果搜索到,显示处该好友信息
D)用户输入DELETE命令后,让用户输入将要删除好友姓名删除,如果存在同
名的多个好友,则列表出,所有同名的好友信息,让用户通过输入ID号删除
提示用户删除成功。
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 _data{ ElementType ID; // ID号 char Name [N]; // 姓名 char Mobile_Phone [N]; // 手机号码 char Home_Address [N]; // 家庭住址 char Company_Tell [N]; // 公司电话}Data;typedef struct _node{Data data;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);void Delete_Pos(PNode head);#endif
#include "head.h"#include <stdio.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~ ~\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->data.ID = num; printf ("\t好友的ID为:%d\n", p->data.ID); printf ("\n"); printf ("\t请输入好友的名字:"); scanf ("%s", p->data.Name); printf ("\n"); printf ("\t请输入好友的手机号:"); scanf ("%s", p->data.Mobile_Phone); printf ("\n"); printf ("\t请输入好友的家庭住址:"); scanf ("%s", p->data.Home_Address); printf ("\n"); printf ("\t请输入好友的公司电话:"); scanf ("%s", p->data.Company_Tell); printf ("\n"); p->next = NULL; //找到最后一个结点 PNode Ptmp; //将头结点地址给临时指针Ptmp Ptmp = 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->data.ID, p->data.Name, p->data.Mobile_Phone, p->data.Home_Address, p->data.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->data.Name, Name))) { printf ("\t好友信息: \n\tID:%d\n\t姓名: %s\n\t手机号码: %s\n\t家庭地址:%s\n\t公司电话: %s\n",q->data.ID, q->data.Name, q->data.Mobile_Phone, q->data.Home_Address, q->data.Company_Tell);printf("\n");printf("\n"); } 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_Pos(PNode head){if (head == NULL)return ;PNode tmp = head;int id;printf("请输入想删除好友的ID:");scanf("%d",&id);while(tmp->next){if (tmp->next->data.ID == id){break;}tmp = tmp ->next;}PNode p = tmp->next;tmp->next = tmp ->next->next;free(p);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");}//删除好友void Delete_Friend (PNode head, char* Name){ PNode p = head->next; int count = 0;while (p){if(strcmp(p->data.Name,Name) == 0){count++;}p = p->next;}if(count == 0)printf("通讯录里没有该好友\n");else if(count == 1){PNode a = head;PNode q = NULL;while (NULL != a && NULL != (a->next)){q = a->next;if (NULL != q && 0 == strcmp(q->data.Name, Name)){a->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(count >1){int id;Search_Friend(head,Name);Delete_Pos(head);}}
main.c
#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;/***********************************************************************打开存放信息的文件并将里面的数据导入到链表中区***********************************************************************/// 以只读方式打开存放信息的文件, FILE *fp1 = fopen ("student.txt", "r+"); if (NULL == fp1) { printf ("fopen"); return -1; } PNode tmp = head_node; int count; int ret; // 保存读记录的个数并判断是否读到文件结尾,如果读到文件结尾,// 它返回一个非0 的值 ret = fread (&count, sizeof(int), 1, fp1); if(ret != 0) { for (i = 0; i < count; i++) {// 创建新结点用来保存读取的数据 Node *node = (Node*)malloc(sizeof(Node)/sizeof(char)); int len; fread (&len, sizeof(int), 1, fp1); // 读取数据长度 fread (&(node->data), len, 1, fp1); // 读取数据 node->next = NULL; while (tmp->next) // 向后遍历 { tmp = tmp->next; } tmp->next = node; // 将结点导入链表中 } } if (ret == 0 && !feof(fp1)) // 读取失败 { perror ("fread"); return -1; } fclose (fp1); // 关闭刚刚打开的文件/***********************************************************************文件导入链表结束,关闭文件***********************************************************************/i = 1;// i初始化(i既是ID编号)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 < 2; 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 < 2; 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://退出通讯录{/************************************************************************退出程序前,将链表中的数据导入到文件中去************************************************************************/// 以更新方式打开存放信息的文件(打开时会清空文件)FILE *fp2 = fopen ("student.txt", "wb+"); if(NULL == fp2) { printf ("fopen"); return -1; } tmp = head_node->next; // tmp为第一个结点count = 0; // 用来存放链表长度while(tmp) // 求链表长度{ count++; tmp = tmp->next; }// 要写入个数fwrite(&count, sizeof(Data), 1, fp2); tmp = head_node; // 初始化while (tmp->next) { Node* p = tmp->next; tmp->next = p->next; // 写入数据的长度 int len = sizeof(p->data); fwrite (&len, sizeof(int), 1, fp2); //写入数据 fwrite (&(p->data), sizeof(Data), 1, fp2); free (p); } fclose (fp2); /************************************************************************数据保存结束,即将退出程序************************************************************************/Function = 0;system ("clear");exit (0);}default: //输入有误{Function = 0;printf ("\t对不起!您的输入有误!请重新输入:");scanf ("%d", &Function);break;}}}return 0;}
阅读全文
0 0
- 通讯录
- 通讯录
- 通讯录
- 通讯录
- 通讯录
- 通讯录
- 通讯录
- 通讯录
- 通讯录
- 通讯录
- 通讯录
- 通讯录
- 通讯录
- 通讯录
- 通讯录
- 通讯录
- 通讯录
- 通讯录
- 读取sift点数据函数
- vs的tool命令makecert生成数字签名证书
- easystruts-1.0.1增加jdbc处理和初始化抽象类
- Stream语法详解
- Linux文件与目录管理
- 通讯录
- C语言(Head First C)-4_3:创建小工具:命令行选项
- Lucene(二)搜索
- opencv中xml文件的制作
- markdown编辑器
- Python接口测试之Requests(七)
- 语法:C++标准库中的iomanip
- angularjs中使用ueditor遇到的一个问题
- ES6之字符串类型(string)