《个人帐簿管理系统设计(共22页).doc》由会员分享,可在线阅读,更多相关《个人帐簿管理系统设计(共22页).doc(22页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精选优质文档-倾情为你奉上数据结构课程设计报告个人帐簿管理系统设计2010年 01 月 21 日目 录1. 引 言-(1)2 需求分析-(2)3 概要设计-(4)4 详细设计-(5)5 测试结果-(6)6 设计体会- (12)7 结束语-(13)8 参考文献-(11)摘 要该课程设计主要设计个人账簿管理系统以记录某人每月的全部收入及各项开支情况,包括食品消费,房租,子女教育费用,水电费,医疗费,储蓄等。在课程设计中,用到了C语言以及数据结构中的相关知识,当然也有少数参考了其他人对某些问题的处理经验。对于进入系统后可以输入和修改某月的收支情况,可以对每月的开支从小到大进行排序,可以根据输入的月份
2、查询每月的收支情况。在程序设计中,添加了使用说明和帮助事项,并且采用了面向对象这种解决问题的方法。程序通过调试运行,初步是想了设计目标,并且经过适当完善后,将可以应用在个人理财解决实际问题。一 引 言本课程设计主要解决在个人帐簿管理系统记录某人每月的全部收入及各项开支情况,包括食品消费,房租,子女教育费用,水电费,医疗费,储蓄等。进入系统后可以输入和修改某月的收支情况,可以对每月的开支从小到大进行排序,可以根据输入的月份查询每月的收支情况。现在是一个科技文化飞速发展的时代,家家户户都可以见到计算机的影子,我们平时的生活,工作以及学习和娱乐都与电脑有着密切的联系。随着经济的发展,理财成为我们生活
3、中不可缺少的内容,理财的重要性显而易见。因此,非常有必要设计一个个人帐薄管理系统,它能够为我们家庭生活个人理财提供诸多方便,使理财更系统,更精确。作为计算机应用的一部分,使用计算机提供个人帐薄管理系统,既继承了传统理财形式,也克服了人工理财的许多缺点,譬如:计算复杂,会时有错误,而用计算机处理的话这种错误可以轻易避免;输入方便,节省了理财人的时间,提高效率和精确度。查询方便、信息详细清晰。便于理财。二 需求分析个人帐薄管理系统具有良好的性能和实用的功能,其性能的良好表现为:输入性强、检索迅速、查询方便、可靠性高等,其实用的功能表现为:由于个人理财所要记载的项目比较琐碎,查询不方便,容易搞错顺序
4、,应用该管理系统可以输入任意每月开支情况,不但不会轻易犯错,而且可以容易修改每月的记录,包括食品消费,房租,子女教育费用,水电费,医疗费,储蓄等。节省时间和空间,这些优点能够促进优化家庭及财政管理,促进财政管理的科技化和现代化。个人帐薄管理系统可以为用户提供任意月份的查询,月份消费信息包括食品消费,房租,子女教育费用,水电费,医疗费,储蓄,具体信息如表2-1所示。表2-1 个人开支项目信息表数字编号名称具体信息1录入数据录入个人每月份的开支情况2查看数据查看所录入月份的开支情况3修改数据如果录入开清情况有误,可以修改4查询数据可以查询所有月份的开支情况5排序数据可以把所要查询的月份的开支情况按
5、从小到大排列6删除数据删除所输入月份的数据0退出系统退出系统三 概要设计设计本系统,首先要认真研读老是给的题目要求,仔细分析设计该题需要用到的技术和知识,同时应该积极查询相关资料,复习有关知识,不懂的地方多向同学以及朋友提问,从而达到事半功倍的想过,也可以参考网上的有关知识帮助有自己解答,总之,就是动用一切可以动用的力量,达到充实自己的目的!以下为该设计系统流程图开始结束0退出系统6删除数据5排序数据4查询数据3修改数据2查询数据1录入数据菜单 图3.0四 详细设计1 算法设计(1)录入、查询、修改、删除数据。建立一个文件,包括某人5个月的开支情况,对文件中的信息扩充,包括修改,删除等。所以先
6、确定文件保存路径,接受键盘输入,像文件内写入内容,将dat格式文件转换为txt文件,查询用声明,自定义数据类型,然后返回查询结果及查询状态,继而对查询结果排序。删除数据时,先调用打开转换的文本文件。修改数据时,要重写数据,删除源文件,重命名中间文件,显示新的数据。 (2)起泡排序 起泡排序是每趟把当先序列中最小的元素放在开始位置,是交换排序中最简单的排序方法,其基本思想是:两两比较相邻记录的关键码,如果反序则交换,值到没有反序的记录为止,将整个待排序的记录序列分成为有序区和无序区,初始状态有序区为空,无序区包括所有待排序的记录。对无序去从前向后依次将相邻记录的关键码进行比较,若反序则交换,从而
7、使得关键码晓得记录向前移,关键码大的记录向后移(像水中的气泡,体积大的先浮上来)。重复执行,之前无序区中没有反序的记录。确定每趟范围。 (3)其基本思想是:先确定文件保存路径,建立一个文件,录入个人5个月的开支情况,对文件中的信息扩充,包括修改,删除等。接受键盘输入,向文件内写入内容,将dat格式文件转换为txt文件,然后输入2进行查看,查看所录入的数据,如果数据有误,可以输入3修改数据,输入4查询所有月份的开支情况,系统自动启用气泡排序对数据精心两两比较,按从小到大的顺序排列。2 实现代码#include #include #include #include /文件保存路径#define F
8、ilePath1 Myinfor.dat#define FilePath2 Myinfor.txt/查询用声明#define Status int#define OK 1#define Error 0#define NotFound 2typedef struct int month;/月份 int food;/食品消费 int house;/房租费用 int edu;/子女教育费用 int elc;/水电费用 int health;/医疗费用 int store;/储蓄费用 int income;/收入费用 Infor;typedef struct / 查询用自定义数据类型 int no;
9、int data; pType;void menu(void); /菜单void input(Infor *newI); /接收键盘输入void writeinfor(Infor *newI);/向文件内写入内容void changeFormat(void );/将dat格式文件转换为txt文件Status search(Infor *a);/查询函数返回查询的结果及查询的状态void paixu(Infor *a);/对查询据结果排序void modify(Infor *a,int mon);/修改数据void delRecord(int mon);/删除数据void main() whil
10、e(1) menu(); void menu(void) int item; int mon; Infor *a; a=(Infor *)malloc(sizeof(Infor); do printf(n个人帐簿管理系统- - 软件082郭帅nn); printf(tt1.录入数据。n); printf(tt2.查看数据。n); printf(tt3.修改数据。n); printf(tt4.查询数据。n); printf(tt5.排序数据。n); printf(tt6.删除数据。n); printf(tt0.退出系统。nn); printf(请输入要进行的操作: ); scanf(%d,&it
11、em); while(item6 | itemmonth; if (item!=OK) printf(n没有符合条件的记录!n); else printf(n记录月份食品消费房租费用子女费用水电费用医疗费用储蓄费用本月收入n); printf(- n); printf(%7d %8d %8d %8d %8d %8d %8d %8dn,a-month,a-food,a-house,a-edu,a-elc,a-health,a-store,a-income); input(a); modify(a,mon); break; /查询数据 case 4: item=search(a); if (ite
12、m!=OK) printf(n没有符合条件的记录!n); else printf(n记录月份食品消费房租费用子女费用水电费用医疗费用储蓄费用本月收入n); printf(- n); printf(%7d %8d %8d %8d %8d %8d %8d %8dn,a-month,a-food,a-house,a-edu,a-elc,a-health,a-store,a-income); break; /排序数据 case 5: item=search(a); if (item!=OK) printf(n没有符合条件的记录!n); else paixu(a); break; /删除数据 case
13、6: item=search(a); mon=a-month; if (item!=OK) printf(n没有符合条件的记录!n); else printf(n记录月份食品消费房租费用子女费用水电费用医疗费用储蓄费用本月收入n); printf(- n); printf(%7d %8d %8d %8d %8d %8d %8d %8dn,a-month,a-food,a-house,a-edu,a-elc,a-health,a-store,a-income); delRecord(mon); break; free(a);/释放内存空间void input(Infor *newI) print
14、f(n请依次输入数据说明:中间以空格符隔开:n(本月月份食品消费房租费用子女费用水电费用医疗费用储蓄费用收入费用)n); scanf(%d%d%d%d%d%d%d%d,&newI-month,&newI-food,&newI-house,&newI-edu,&newI-elc,&newI-health,&newI-store,&newI-income); fflush(stdin);void writeinfor(Infor *newI) FILE *fp; fp=fopen(FilePath1,ab+); if(fp=NULL) printf(无法创建文件:%s,FilePath1); ex
15、it(0); fwrite(newI,sizeof(Infor),1,fp);/这里可以做特别处理可防止存在同一月份有条以上的记录问题。这里就不写了。 fclose(fp); printf(数据录入成功!n);void changeFormat(void) /暂时只能操作一行文件有待改进 FILE *fp1,*fp2; Infor *a; a=(Infor *)malloc(sizeof(Infor); fp1=fopen(FilePath1,rb+); if(fp1=NULL) printf(无法找到文件:%sn,FilePath1); return ; /返回主函数 fp2=fopen(F
16、ilePath2,wt+); if(fp2=NULL) printf(无法创建文件:%sn,FilePath2); return ; /返回主函数 fputs( n个人帐簿管理系统nn,fp2); fputs(记录月份食品消费房租费用子女费用水电费用医疗费用储蓄费用本月收入n,fp2); fputs(- n,fp2); printf(n记录月份食品消费房租费用子女费用水电费用医疗费用储蓄费用本月收入n); printf(- n); rewind(fp1); fread(a,sizeof(Infor),1,fp1); while(!feof(fp1)/从原文件.dat中读数据写入显示文件.txt
17、中 printf(%7d %8d %8d %8d %8d %8d %8d %8dn,a-month,a-food,a-house,a-edu,a-elc,a-health,a-store,a-income); fprintf(fp2,%7d %8d %8d %8d %8d %8d %8d %8dn,a-month,a-food,a-house,a-edu,a-elc,a-health,a-store,a-income); fread(a,sizeof(Infor),1,fp1); fputs(- n,fp2); fputs(关闭本程序继续原程序!n,fp2); fclose(fp1); fcl
18、ose(fp2); system(FilePath2); /调用打开转换的文本文件 remove(FilePath2);/删除文本文件文件Status search(Infor *a) FILE *fp1; int mon; int isfound=0; printf(请正确输入要查询的月份:); scanf(%d,&mon); fflush(stdin); /清除缓冲区 fp1=fopen(FilePath1,rb+); if(fp1=NULL) printf(无法找到文件:%sn,FilePath1); return Error; /返回主函数 rewind(fp1); fread(a,s
19、izeof(Infor),1,fp1); while(!feof(fp1)/查询操作 if(a-month=mon) isfound=1; break; else isfound=0; fread(a,sizeof(Infor),1,fp1); fclose(fp1); if(isfound) return OK; else return NotFound;void paixu(Infor *a) int i=0,j=0,flag=0,t; pType px8=0,0; char str810=记录月份,食品消费,房租费用,子女费用,水电费用,医疗费用,储蓄费用,本月收入; for(;imon
20、th; px1.data=a-food; px2.data=a-house; px3.data=a-edu; px4.data=a-elc; px5.data=a-health; px6.data=a-store; px7.data=a-income; for(i=1;i8;i+)/冒泡排序 flag=0; for(j=0;jpxj+1.data) t=pxj.data; pxj.data=pxj+1.data; pxj+1.data=t; t=pxj.no; pxj.no=pxj+1.no; pxj+1.no=t; flag=1; /输出结果 if(flag=0) break; printf
21、(n); for(i=0;i8;i+) printf( %s,strpxi.no); printf(n- n); for(i=0;imonth=mon) fwrite(a,sizeof(Infor),1,fp2);/修改数据 else fwrite(b,sizeof(Infor),1,fp2); fread(b,sizeof(Infor),1,fp1); fclose(fp1); fclose(fp2);remove(FilePath1); /删除源文件 rename(temp.dat,FilePath1);/重命名中间文件 printf(修改数据成功!n ); changeFormat();
22、 /显示数据void delRecord(int mon) /删除数据 FILE *fp1,*fp2; Infor *b; b=(Infor *)malloc(sizeof(Infor); fp1=fopen(FilePath1,rt); fp2=fopen(temp.dat,wt+);rewind(fp1); fread(b,sizeof(Infor),1,fp1); while (!feof(fp1) /重写数据 if(b-month!=mon) fwrite(b,sizeof(Infor),1,fp2); fread(b,sizeof(Infor),1,fp1); fclose(fp1)
23、; fclose(fp2);remove(FilePath1); /删除源文件 rename(temp.dat,FilePath1);/重命名中间文件 printf(删除数据成功!n ); changeFormat(); /显示数据五 具体实现及运行结果5.1 创建工程并建立文件(1)启动C FREE(2)新建工程名为“zj” 的Win32控制台应用程序。(3)建立头文件“Myinfor.h”,在其中定义图类myinfor。(4)建立源文件“myinfor。.cpp”,在其中定义图类myinfor。的构造函数myinfor。、开支情况输出输出函数PutOutVexInfo。(5)建立源文件“m
24、yinfor Main.cpp”,在其中输入开支情况及项目信息,通过主函数调用其它各函数,实现个人帐薄管理系统的设计个人帐薄管理系统的实现图5.1(1) 如果输入1,进行录入数据,并且录入某人从1-5月的开支情况。图5.2图5.3 1月份开支情况信息录入图5.4 2月份开支情况信息录入图5.5 3月份开支情况信息录入图5.6 4月份开支情况信息录入图5.7 5月份开支情况信息录入(2)查看数据,输入2.图5.8 开支情况信息查询图5.9图5.10 信息修改图5.11 5月份开支情况费用排序图5.12 开支情况记录删除图5.13 个人帐簿管理系统退出六 设计体会本次设计给我们带来了很深的感触,C
25、语言的精深以及程序的可爱都深深地吸引了我们,这次设计使我们自身的编程,读程能力得到了提升,也使我们更加深刻的认识到不断学习,努力探索的重要性,本次设计单凭自己的力量真的有些困难,幸亏有同学的帮助以及各种参考资料以供查询,以及自身不断努力和奋进,最终也得到一个令人还算满意的结果,总之,我在这次设计中体会到了自己的不足之处,我会在以后的学习和生活中将自身的水平完善,最终使自己拥有傲人的能力!七 结束语就要放假了,课程设计也已经到了收尾阶段,经过这次设计,我真的被深深地触动了,不管怎么样,利用假期时间,以及以后的学习中,我都要不断钻研,不仅仅局限于课本上的知识,还要吸收一切对自己的编程能力,创新能力有帮助的东西,总之,在以后的工作和学习中,我会更加努力地学习,题为学习,体味生活。非常感谢黄伟东老师给了我们这次实践机会,还要感谢各个帮助过我的朋友和同学们,最后,祝大家新年快乐,万事如意。参考文献1 数据结构(C语言版),严蔚敏2 C程序与设计第三版, 谭浩强3 数据结构习题、实验. 朱建芳专心-专注-专业
限制150内