个人帐簿管理系统设计_第1页
个人帐簿管理系统设计_第2页
个人帐簿管理系统设计_第3页
个人帐簿管理系统设计_第4页
个人帐簿管理系统设计_第5页
已阅读5页,还剩17页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

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排序数据可以把所要查询的月份的开支情况按从小到大排列6删除数据删除

5、所输入月份的数据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 <stdio.h>#include <stdlib.h>#include <mem

8、ory.h>#include <windows.h>/文件保存路径#define FilePath1 "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;/医疗费用

9、int store;/储蓄费用 int income;/收入费用 Infor;typedef struct / 查询用自定义数据类型 int no; 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

10、modify(Infor *a,int mon);/修改数据void delRecord(int mon);/删除数据void main() while(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

11、"); printf("tt4.查询数据。n"); printf("tt5.排序数据。n"); printf("tt6.删除数据。n"); printf("tt0.退出系统。nn"); printf("请输入要进行的操作: " ); scanf("%d",&item); while(item>6 | item<-1); switch(item) /退出程序 case 0: getchar();/保存界面 getchar(); exit(0); b

12、reak; /录入数据 case 1: input(a); writeinfor(a); break; /查看数据 case 2: changeFormat(); break; /修改数据 case 3: item=search(a); mon=a->month; if (item!=OK) printf("n没有符合条件的记录!n"); else printf("n记录月份食品消费房租费用子女费用水电费用医疗费用储蓄费用本月收入n"); printf("- n"); printf("%7d %8d %8d %8d %

13、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 (item!=OK) printf("n没有符合条件的记录!n"); else printf("n记录月份食品消费房租费用子女费用水电费用医疗费用储蓄费用本月收入n"); printf("

14、;- 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 6: item=search(a); mon

15、=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); delRe

16、cord(mon); break; free(a);/释放内存空间void input(Infor *newI) printf("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->

17、store,&newI->income); fflush(stdin);void writeinfor(Infor *newI) FILE *fp; fp=fopen(FilePath1,"ab+"); if(fp=NULL) printf("无法创建文件:%s",FilePath1); exit(0); fwrite(newI,sizeof(Infor),1,fp);/这里可以做特别处理可防止存在同一月份有条以上的记录问题。这里就不写了。 fclose(fp); printf("数据录入成功!n");void chan

18、geFormat(void) /暂时只能操作一行文件有待改进 FILE *fp1,*fp2; Infor *a; a=(Infor *)malloc(sizeof(Infor); fp1=fopen(FilePath1,"rb+"); if(fp1=NULL) printf("无法找到文件:%sn",FilePath1); return ; /返回主函数 fp2=fopen(FilePath2,"wt+"); if(fp2=NULL) printf("无法创建文件:%sn",FilePath2); return ;

19、 /返回主函数 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中 prin

20、tf("%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

21、(a,sizeof(Infor),1,fp1); fputs("- n",fp2); fputs("关闭本程序继续原程序!n",fp2); fclose(fp1); fclose(fp2); system(FilePath2); /调用打开转换的文本文件 remove(FilePath2);/删除文本文件文件Status search(Infor *a) FILE *fp1; int mon; int isfound=0; printf("请正确输入要查询的月份:"); scanf("%d",&mon);

22、fflush(stdin); /清除缓冲区 fp1=fopen(FilePath1,"rb+"); if(fp1=NULL) printf("无法找到文件:%sn",FilePath1); return Error; /返回主函数 rewind(fp1); fread(a,sizeof(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

23、(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(;i<8;i+) pxi.no=i; px0.data=a->month; px1.

24、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;i<8;i+)/冒泡排序 flag=0; for(j=0;j<8-i;j+) if(pxj.data>pxj+1.data) t=pxj.data; pxj.data=pxj+1.data; pxj+1.data=t; t=pxj.no; pxj.no=pxj+1.no;

25、 pxj+1.no=t; flag=1; /输出结果 if(flag=0) break; printf("n"); for(i=0;i<8;i+) printf(" %s",strpxi.no); printf("n- n"); for(i=0;i<8;i+) printf("%8d ",pxi.data); printf("n");void modify(Infor *a,int mon)/修改数据 FILE *fp1,*fp2; Infor *b; b=(Infor *)mall

26、oc(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(a,sizeof(Infor),1,fp2);/修改数据 else fwrite(b,sizeof(Infor),1,fp2); fread(b,sizeof(Infor),1,fp1); fclose(fp

27、1); fclose(fp2);remove(FilePath1); /删除源文件 rename("temp.dat",FilePath1);/重命名中间文件 printf("修改数据成功!n" ); changeFormat(); /显示数据void delRecord(int mon) /删除数据 FILE *fp1,*fp2; Infor *b; b=(Infor *)malloc(sizeof(Infor); fp1=fopen(FilePath1,"rt"); fp2=fopen("temp.dat",&

28、quot;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); fclose(fp2);remove(FilePath1); /删除源文件 rename("temp.dat",FilePath1);/重命名中间文件 printf("删除数据成功!n" ); changeFormat(); /显

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论