怎样编制通讯录程式
2008-02-23 05:32:32来源:互联网 阅读 ()
电子通讯录功能如下:
Function choose
1.Read
2.Append
3.Delete
4.Search
5.Save and exit
6.Quit
说明:上图是电子通讯录的主菜单,利用他,将能够轻松地录入一个朋友的电话号
码,通讯地址和出生日期,而且他还提供了检索和删除功能。在后面还将提供按生
日先后排序的功能,这些都有助于该通讯录的管理。
电子通讯录是采用线性表作为程式的基本结构的。
设计思想:
1。用顺序表设计电子通讯录的结构
为了表示较为复杂的数据内容,一般用结构这种数据类型,第一步就是在结构中定
义所需要的各项信息。
一般的通讯录都包括姓名,性别,出生年月,通讯地址和联系电话这几项,而
在这几项中,出生年月又包括年份,月份和日期三项,通讯地址包括邮编和家庭地
址二项,我们把这些联系较为紧密的内容又用单独的结构表示,这样就产生了电子
通讯录的基本结构:
struct addr /*通讯地址结构定义*/
{ char post_num[10]; /*邮编*/
char addr[40]; /*家庭地址*/
};
struct birth /*出生年月结构定义*/
{ int year; /*年份*/
int month; /*月份*/
int day; /*日期*/
};
struct friend /*电子通讯录结构定义*/
{ int number; /*序号*/
char name[20] /*姓名*/
char sex; /*性别*/
struct birth birth; /*出生年月*/
struct addr addr; /*通信地址*/
char telephone[13]; /*联系电话*/
};
定义的主结构friend包含了前述的五项内容 name,sex,和telephone分别代表
了姓名,性别和联系电话。为了让结构中的各项组分更加清楚,定义了二个
小结构birth 和addr分别代表出生年月和通讯地址,因此实际上friend包含了
8项内容。
有了结构定义后,我们能够很轻松地构造出电子通讯录的主体:
stryct friend friends[50];
采用一维数组 friends[50],正是用到了顺序表这种最简单的数据结构来表示
问题。
2.增添电子通讯录中的内容
对于电子通讯录这样一张顺序表来说,内容的录入是必不可少的操作。由
于采用的是顺序存储结构。这项工作很简单,只需要在把输入的信息按顺序放
在空的friends数组元素中即可。函数Data_Input完成了信息的录入工作:
void Data_input(int j)
{
friends[j].number=j;
printf("\n\n\n\tNo %d record",j);
printf("\n\n\tName:"); /*读入姓名*/
scanf("%s",friends[j].name);
printf("\n\tSex(m/f):"); /*读入姓别*/
scanf("%c",&friends[j].sex);
printf("\n\tbirthday:"); /*读入出生年月*/
printf("\n\t\tyear:");
scanf("%d",&friends[j].birth.year);
printf("\n\t\tmonth");
scanf("%d",&friends[j].birth.month);
printf("\n\t\tday");
scanf("%d",&friends[j].birth.day);
printf("\n\tPost number:"); /*读入邮编*/
scanf("%s",friends[j].addr.post_num);
printf("\n\tAddress:"); /*读入家庭地址*/
scanf("%s",friends[j].addr.addr);
printf("\n\ttelephone:"); /*读入联系电话*/
scanf("%s",friends[j].telephone);
}
录入完毕后典型的一份信息如下所示:
NO: 1
Name: 张三
Sex: m
Birthday(y/m/d): 1980 5 12
Postnum: 100034
Address: Beijing University
Tele: (010)62005200
3.电子通讯录记录的维护(插入和删除)
在实际使用中,数据资料输入后,还需要不断的更新和维护操作,最常见的是数
据的插入和删除。作为顺序表来说,如何在插入和删除数据资料后仍然能保持
原有数据之间的关系,是需要考虑的关键问题。
电子通讯录的插入算法如下:
printf("\n\tInsert No:"); /*录入插入位置*/
scanf("%d",&k);
for(j=i 1;j>k;j--) /*插入位置后的元素顺序后移*/
{ strcpy(friends[j].name,friends[j-1].name); /*交换元素内容*/
friends[j].sex=friends[j 1].sex;
friends[j].birth.year=friends[j-1].birth.year;
friends[j].birth.month=friends[j-1].birth.month;
friends[j].birth.day=friends[j-1].birth.day;
strcpy(friends[j].addr.post_num,friends[j-1].addr.post_num);
strcpy(friends[j].addr.addr,friends[j-1].addr.addr);
strcpy(friends[j].telephone,friends[j-1].telephone);
}
Data_Input(k); /*插入位置上填入待插入元素*/
i ; /*总元素个数增1*/
删除算法如下:
printf("\n\tDelete No:"); /*读入删 除位置*/
scanf("%d",&k);
for(j=k;j<i;j ) /*删 除位置前的元素顺序前移*/
{
strcpy(frinds[j].name,frinds[j 1].name);
friends[j].sex=frinds[j 1].sex;
friends[j].birth.year=friends[j 1].birth.year;
friends[j].birth.month=friends[j 1].birth.month;
frinds[j].birth.day=friends[j 1].birth.day;
strcpy(friends[j].addr.post_num,friends[j 1].addr.post_num);
strcpy(friends[j].addr.addr,friends[j 1].addr.addr);
strcpy(friends[j].telephone,friends[j 1].telephone);
}
i--; /*元素总数减1*/
函数search的代码如下:
search()
{
printf("\n\tPlease input name:"); /*提示输入要查询的姓名*/
gets(search_name);
for(j=1;j<=i;j )
{ if(strcmp(search_name,friends[j].name)==0) /*比较二个串*/
{ Data_Show(j); /*查询成功,打印记录,结束循环*/
break;
}
}
if(j>1) /*查询失败,给出提示信息*/
printf("\n\t No such records");
}
文档存盘代码如下
FILE *fp;
void Data_Save()
{
int j;
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇: c 编的学生个人消费管理系统
下一篇: C 中通过重载避免隐式类型转换
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash