资源描述
西 安 邮 电 学 院
高级语言课程设计
实验报告
系 别:电 信 系
专业班级:科技0701班
学 号:05072007
班序号:07
姓 名:朱 岩
指导老师:黄 茹
实验课题:学生通讯信息管理系统
实验时间:2008.6.10~2008.6.20
2008年6月17日
一、实验目的
1. 熟悉C语言的编译,和运行过程;
2. 掌握C语言的数据类型,熟悉整型、实型、字符型变量的定义方式与如何给它们赋值,掌握不同的类型数据之间的赋值规律,赋值使用方法;
3. 掌握if语句与switch语句的运用方法与嵌套应用方法;
4. 掌握实现循环结构的三种语句while、 do-while.、for 的使用;
5. 掌握C语言函数的定义,声名与调用方法和调用过程;
6. 掌握C语言主函数和被调用函数之间的参数传递方式,学会函数的嵌套调用和递归调用的过程和方法;
7. 掌握数组的定义,赋值引用与输入输出方法,并正确用字符数组储存字符串,学会字符串的使用;
8. 掌握结构体类型变量的定义和使用;
9. 掌握指针变量和指向指针的指针变量的定义与使用,进一步了解指向结构体数组的指针变量的概念与使用方法;
10. 掌握链表的概念与链表的操作,并理解链表与数组的不同点与优缺点;
11. 掌握文件和文件指针的定义与文件建立,打开,关闭,读写等的操作方法
12. 能够采用模块化思想调试程序;
二.实验容
1. 编写程序并进行调试运行;
2. 输入学生通讯信息并保存于文件,每个学生包含信息如:序号,,省份,,生日, ,大学,班级, 号信息;
3. 对已存入的学生信息进行更新操作,包括添加一个学生信息、删除某个学生信息和修改某个学生信息;
4. 通过输入,学号的方式查询学生信息;
5. 可以通过省份,生日来统计通讯信息;
6. 最后输出学生信息,供需要时打印。
一、 需求分析
1. 该程序可用于对学生的通讯方式基本信息的存储、更新、查询、输出等操作,以实现对学生通讯录信息的管理,便于同学之间的联系交往;
2. 其中更新功能包括:添加信息,删除信息,修改信息,可根据需要添加一个或多个学生信息,也可针对个别学生信息进行适当的删除或修改,以便随时更新学生通讯信息。
3. 程序中设计的查询功能可根据需要从若干数据中查询某个学生信息,并且可根据两种不同的方法查询:按查询和按查询,以满足不同的需要;
4. 可以通过输出的方式查看整个通讯录;
5. 可以通过排序的方式查看同学生日的先后。
四、概要设计
1、方案设计
对系统进行分析,给出结构图
分析:系统要实现许多功能,因此遵循结构化程序设计思想来进行本系统的设计:—,自顶向下逐步细化,将系统设计任务分解出许多子功能模块来计;
结构图如下:学生通讯录信息管理系统
选 择 模 块
退出
系
统
退
出
模
块
排序
模
块
查
询
模
块
操作
模
块
输
出
模
块
输
入
模
块
添
加
模
块
删
除
模
块
修
改
模
块
按
姓
名
按
退
出
模
块
按
XX
序号
退
出
模
块
保 存 通 讯 信 息
2 . 模块功能说明
对各个模块进行功能的描述
(1).输入模块:
录入需要管理的通讯信息并将信息保存于文件中,以方便日后进行打印、读取、更新等操作。
(2).添加模块:
可添加一个或多个学生的通讯信息,并将所添加的信息保存,方便查找。
(3).删除模块:
可对失去联系的学生通讯信息做删除处理。
(4).修改模块:
可对通讯信息发生改变的学生信息进行修改。
(5).查询模块:
可对已建立的学生通讯信息进行查询,并且可根据需要选择按查询或按查询。
(6).保存模块:
用于对通讯信息进行保存。
(7).输出模块:
将所有学生通讯信息或想要查询的学生信息显示于屏幕,用于打印学生通讯信息或查找某些学生通讯信息。
(8).退出系统:
选择该项,自动退出该系统。
五、详细设计与运行结果
流程图, 函数之间相互调用的图示 ,程序设计与编码, 运行结果。
开 始
输 入 变 量 i
判断i的值
排序
模
块
查
询
模
块
操作
模
块
显示
模
块
输
入
模
块
退
出
模块
添
加
模
块
删
除
模
块
插入
模
块
按
姓
名
按
号码
退
出
模
块
XX
序号
退
出
模
块
判断i值
输入变量
退
出
模
块
输入变量
判断i值
输入变量
判断i值
保 存 模 块
结 束
输入模块: 显示模块:
开 始
开 始
i=0
i=0
i<sum
i<sum
输入通讯信息
输入通讯信息
i++
i++
m==y s[i].num!=0
结 束
sum=i
结 束
开始
开始
排序模块: 操作模块:
输入i的值
i=0
j=i+1
判断i的值
XX的字符串相等?
否
退
出
模
块
删除模块
插入模块
添加模块
是 i=1 i=2 i=3
交换i与j的信息
j=j+1
j<sum
是
否
返回主界面
i=i+1
i<sum-1
结束
是 否
输出信息
结束
输入i
开始
XX排序
退出系统
判断i值
输入i
开始
快速查找
判断i值
查询模块: 排序模块:
返回主界面
结束
XX查询
查询
序号
返回主界面
结束
六. 调试情况与运行结果
1.对自己设计进行评价,指出合理和不足之处,提出改进的方案。
此次实践课编写的是一个应用程序,相对于以前我们见到的程序,它要大得多,运行的结果也没有预想中的好,数据的输出格式不太规,而且各模块也出现了一些小问题,在同学们的帮助下,我很有耐心的一次又一次的进行修改,最后运行的结果基本上达到了预期的目的。可着毕竟是第一次独立完成这样的大程序,结果还不是太理想。
由于时间很短,在选题报告中设想到的好多功能都没有实现。已有的那些功能虽已能基本上满足用户的需要,但如果还有更多的功能程序就会更加完美。如:再录入数据时,没有设计数据输入出错的提示。
2.在设计过程中的感受。
本次C 语言的实习课让我对C 语言的学习又有了更深入的了解,也让我更深刻地领悟到了“实践出真理”这个道理,在上机实践过程中学到的知识远远超过了在课堂上十几周学到的,学校组织的这次实习让我们这些实践知识匮乏的大学生增添了许多社会经验,为我们将来走上工作岗位其了不小的铺垫作用。
本次实习中遇到了很多以前没有遇到过的问题,也曾想过要放弃,但看到那些同学都在那认真的写程序,给了我继续的信心。在同学的帮助下,我顺利的结束了本次实习,让我知道原来凭借自己努力取得的成功会让自己这么欣慰,也让我知道了友谊和团结的重要性。并且,通过一种题材两中方式的学习,我掌握了更多的知识,也认识到对比学习的重要性。
七.参考文献
参考书名 编者XX 出版时间
《C语言程序设计》 王曙燕 曹锰 科学 2005年2月
《C语言程序设计》 谭浩强 清华大学 1999年12月
参考书名 编者 出版时间
《C语言程序设计》 王曙燕 锰 科学 2005年2月
八。附录:
1. 链表方式:
#include<stdio.h>
#include<string.h>
#define N sizeof(struct stud)
#include <math.h>
#include <conio.h>
#include <stdlib.h>
/*日期结构体类型*/
struct date
{int y;
int m;
int d;
}bir;
/*学生信息结构体类型*/
struct stud
{
int num; /*序号*/
char name[20]; /**/
char tel[40]; /**/
char addr[40]; /*省份*/
char yb[20]; /* */
char daxue[50]; /*大学*/
struct date bir; /*生日*/
struct stud *next;
};
char a;
struct stud *h;
FILE *fp;
/*建立链表*/
struct stud *creat()
{ int i,k;
struct stud *p1,*p2,*head;
printf("\n请输入学生数:\n");
scanf("%d",&k);
head=NULL;
head=p1=p2=(struct stud *)malloc(N); /*head,p1,p2指向首结点*/
for(i=0;i<k;i++)
{p1=(struct stud *)malloc(N); /*p1指向新申请的结点*/
printf("\n请输入序号:");
scanf("%d",&p1->num);
printf("\n请输入:");
scanf("%s",p1->name);
printf("\n请输入:");
scanf("%s",p1->tel);
printf("\n请输入籍贯:");
scanf("%s",p1->addr);
printf("\n请输入 :");
scanf("%s",p1->yb);
printf("\n请输入大学:");
scanf("%s",p1->daxue);
printf("\n请输入出生日期:(年-月-日)");
scanf("%d-%d-%d",&p1->bir.y,&p1->bir.m,&p1->bir.d);
p2->next=p1; /*将新结点到表尾*/
p2=p1; /*p2指向新的表尾*/
}
p2->next=NULL;
head=head->next; /*头指针后移*/
save_message(head); /*立即保存*/
return head;
}
/*输入模块*/
input_message()
{clrscr();
printf("\n\n**********输入学生信息**********\n");
printf("-----------------------------------\n");
h=creat();
bioskey(0);
printf("输入完毕,按任意键返回主菜单!");
bioskey(0);
}
/*输出模块*/
output_message(struct stud *p)
{clrscr();
if(p==NULL)
printf("暂无信息!请回主菜单录入信息!\n");
else
{printf("\n\n=======================通讯录信息表======================\n\n");
printf("=省份=========生日(年-月-日)= ======大学\n");
while(p!=NULL)
{printf("-----------------------------------------------------------------------\n");
printf("%s %s %s %d-%d-%d %s %s\n",p->name,p->addr,p->tel,p->bir.y,p->bir.m,p->bir.d,p->yb,p->daxue);
printf("-----------------------------------------------------------------------\n");
printf("\n");
p=p->next;
}
}
printf("\n");
printf("按任意键返回主菜单!\n\n");
bioskey(0);
}
/*保存学生信息*/
save_message(struct stud *h)
{FILE *fp;
struct stud *f;
f=h; /*保证指针位置*/
if((fp=fopen("zhuyan.txt","wb"))==NULL)
{printf("不能打开文件!\n");
return;
}
while(h!=NULL)
{if(fwrite(h,sizeof(struct stud),1,fp)!=1) /*向文件写入数据*/
{printf("文件写入错误!");
return;
}
h=h->next;
}
h=f; /*保证指针位置*/
printf("已存盘,按任意键回上层菜单:\n");
getch();
fclose(fp);
return;
}
/*读取信息*/
read_message()
{FILE *fp;
if((fp=fopen("zhuyan.txt","rb"))==NULL)
{printf("\n\n****暂时还没有该生信息,请按任意键返回上一级菜单.\n");
return;
}
do
{if(fread(h,sizeof(struct stud),1,fp)!=1)
{if(feof(fp))
printf("已到文件末尾.\n"); /*已到文件末尾.*/
else printf("文件读取错误!\n"); /*文件读取错误.*/
return;
}
h=h->next;
}while(h!=NULL);
fclose(fp);
getch();
bioskey(0);
}
/*添加学生信息*/
add_message(struct stud *w)
{struct stud *p,*q;
p=(struct stud*)malloc(N); /*p指向新申请的结点*/
clrscr();
printf("\n请输入学生序号:");
scanf("%d",&p->num);
printf("\n请输入学生:");
scanf("%s",p->name);
printf("\n请输入学生:");
scanf("%s",p->tel);
printf("\n请输入学生籍贯:");
scanf("%s",p->addr);
printf("\n请输入学生 :");
scanf("%s",p->yb);
printf("\n请输入学生大学:");
scanf("%s",p->daxue);
printf("\n请输入学生出生日期:");
scanf("%d-%d-%d",&p->bir.y,&p->bir.m,&p->bir.d);
p->next=NULL;
if(w==NULL)
{w=p; /*头指针为空,p作为新头指针*/
return 1; /*正确插入返回1*/
}
q=w; /*从头指针开始*/
if((q->num)>(p->num)) /*找到插入位置在首结点之前*/
{p->next=w; /*将首结点在新结点之后*/
w=p; /*p作为新的头指针*/
return 1;
}
while((q->next)!=NULL && (q->next->num)<(p->num))
q=q->next; /*继续查找插入位置*/
if(q->next==NULL) /*插入位置在尾结点之后*/
{q->next=p; /*新结点到尾结点之后*/
return 1;
}
else if((q->next->num)==(p->num)) /*找到重号*/
{free(p); /*释放新结点的存储空间*/
return 0; /*不插入返回0*/
}
p->next=q->next; /*后续结点到新结点之后*/
q->next=p; /*新结点到前驱结点之后*/
return 1;
}
/*删除模块*/
del_message(struct stud *w)
{char name[20];
struct stud *p,*q;
if(w==NULL)
return 0; /**w就是头指针,空表不能删除返回0*/
clrscr();
printf("请输入要删除的学生:\n");
scanf("%s",name);
q=w;
if(strcmp(q->name,name)==0) /*找到要删除的是第一个结点*/
{w=q->next; /*修改头指针*/
free(q); /*释放存储空间*/
return 1; /*正确删除返回1*/
}
p=q->next;
while(p!=NULL)
{if(strcmp(p->name,name)==0) /*找到要删除的结点*/
{q->next=p->next; /*后续结点连接到前驱结点之后*/
free(p); /*释放存储空间*/
return 1;
}
q=p; /*推移指针继续查找*/
p=p->next;
}
return 0; /*未找到要删除的结点返回0*/
}
/*修改模块*/
revise_message(struct stud *g)
{int choice;
char name[20],n,m;
do
{clrscr();
printf("\n **********学生学籍信息*********** \n");
printf(" 输入要修改的学生:\n");
scanf("%s",name);
while(g!=NULL)
{ while(strcmp(g->name,name)!=0)
g=g->next;
if(g==NULL)
{printf("\n 该学生不存在!");
bioskey(0);
}
else
{do
{printf("\n 您要修改哪一项?\n");
printf("\n 1序号\n");
printf("\n 2\n");
printf("\n 3籍贯\n");
printf("\n 4\n");
printf("\n 5大学\n");
printf("\n 6出生日期\n");
scanf("%d",&choice);
switch(choice)
{case 1:printf("\n 请输入修改后的序号:");
scanf("%d",&g->num);break;
case 2:printf("\n 请输入修改后的:");
scanf("%s",g->name);break;
case 3:printf("\n 请输入修改后的籍贯:");
scanf("%s",g->addr); break;
case 4:printf("\n 请输入修改后的:");
scanf("%s",g->tel); break;
case 5:printf("\n 请输入修改后的大学:");
scanf("%s",g->daxue); break;
case 6:printf("\n 请输入修改后的出生日期:");
scanf("%d-%d-%d",&g->bir.y,&g->bir.m,&g->bir.d);break;
}
printf("\n是否继续修改此人信息?y/n\n") ;
getchar();
m=getchar();
}while(m=='y');
printf("\n\n=======================通讯录信息表======================\n\n");
printf("=省份=========生日(年-月-日)= ======大学\n");
printf("-----------------------------------------------------------------------\n");
printf("%s %s %s %d-%d-%d %s %s\n",g->name,g->addr,g->tel,g->bir.y,g->bir.m,g->bir.d,g->yb,g->daxue);
printf("-----------------------------------------------------------------------\n");
printf("\n");
getch();
}
break;
}
printf("\n要继续吗?(y/n)\n");
getchar();
n=getchar();
}while(n=='y');
printf("\n 按任意键返回主菜单!");
bioskey(0);
}
/*更新模块*/
renew_message()
{int choice=100;
while(choice!=0)
{printf("\n************更新同学信息*************\n\n");
printf(" 1.添加同学信息\n\n");
printf(" 2.删除同学信息\n\n");
printf(" 3.修改同学信息\n\n");
printf(" 0.返回修改菜单\n\n");
printf(" 请选择(0—3):\n");
printf("******************************************\n\n");
scanf("%d",&choice);
switch(choice)
{case 1:add_message(h);break;
case 2:del_message(h);break;
case 3:revise_message(h);break;
case 0:break;
default:printf("输入有误!\n");
}
}
}
/*按查询*/
inquire_name( struct stud *p)
{ char name[20];
struct stud *f;
f=p;
clrscr();
printf("\n\n 请输入要查找的:");
scanf("%s",&name);
if(p==NULL)
{printf("\n您要查找的学生暂时不存在,请按任意键返回\n");
bioskey(0);
}
else if (strcmp(p->name,name)!=0||p->name==NULL)
p=p->next;
clrscr();
printf("\n\n该生有关信息为:\n\n\n\n");
printf("\n\n=======================通讯录信息表======================\n\n");
printf("=省份=========生日(年-月-日)= ======大学\n");
printf("-----------------------------------------------------------------------\n");
printf("%s %s %s %d-%d-%d %s %s\n",p->name,p->addr,p->tel,p->bir.y,p->bir.m,p->bir.d,p->yb,p->daxue);
printf("-----------------------------------------------------------------------\n");
printf("\n");
p=f;
getch();
}
/*按学号查询*/
inquire_tel(struct stud *p)
{char tel[20];
struct stud *f;
f=p;
clrscr();
printf("\n 请输入要查找的:");
scanf("%s",&tel);
if(p==NULL)
{printf("\n您要查找的学生暂时不存在,请按任意键返回\n");
bioskey(0);
}
else if(strcmp(p->tel,tel)!=0||p->tel==NULL)
p=p->next;
clrscr();
printf("\n\n该生有关信息为:\n\n\n\n");
printf("\n\n=======================通讯录信息表======================\n\n");
printf("=省份=========生日(年-月-日)= ======大学\n");
printf("-----------------------------------------------------------------------\n");
printf("%s %s %s %d-%d-%d %s %s\n",p->name,p->addr,p->tel,p->bir.y,p->bir.m,p->bir.d,p->yb,p->daxue);
printf("-----------------------------------------------------------------------\n");
printf("\n");
p=f;
getch();
}
/*查询模块*/
inquire_message()
{int choice=100;
while(choice!=0)
{printf("\n***********************查询同学通讯信息**********************\n");
printf(" 1.按同学查询:\n");
printf(" 2.按同学查询:\n");
printf(" 0.返回主菜单:\n");
printf(" 请选择(0—2):\n");
scanf("%d",&choice);
switch(choice)
{case 1:inquire_name(h);break;
case 2:inquire_tel(h);break;
case 0:break;
default:printf("无此类查询方式!\n");
}
}
}
/*省份统计*/
count_ad(struct stud *p)
{int count=0;
char count_ad[20];
printf("\n 输入要统计的省份名称:\n");
scanf("%s",count_ad);
if(p=NULL)
{printf("\n 该学生不存在!");
bioskey(0);
}
else
{printf(" 在该省份的同学:\n");
printf("=省份=========生日(年-月-日)= ======大学\n");
printf("-----------------------------------------------------------------------\n");
p=h; /*p指向头指针!*/
while(p!=NULL)
{ if(strcmp(p->addr,count_ad)==0)
{printf("%s %s %s %d-%d-%d %s %s\n",p->name,p->addr,p->tel,p->bir.y,p->bir.m,p->bir.d,p->yb,p->daxue);
展开阅读全文