1、目 录1 引言12 系统需求分析12。1项目背景分析12.2 系统开发的目标与意义12.3 项目需求分析13 系统总体设计13。1 功能模块分析13。2 系统功能模块初始化准备33。2.1 编译预处理33。2。2 数据结构定义33.3 具体模块处理函数的实现43.3。1 菜单函数界面的设计43.3.2 功能函数设计44 系统测试与分析94。1 运行工具介绍94。2 系统操作9结束语10参考文献109计算机与信息工程系毕业设计研究报告用C语言实现一个简单的学生成绩管理系统摘要:伴随着现代社会的发展,网络技术的不断进步,越来越多的管理工作都从传统的现实社会中发展到了网络上。高校是使用计算机技术最早
2、的单位,学校的各项管理工作也从现实生活走上了网络空间。本文对学校的需求进行分析,通过使用C语言设计并实现学生成绩的管理,力求尽量简洁实用地解决学校对学生成绩的管理和学生对成绩的查询问题.关键字:C语言 成绩管理系统 程序设计1 引言在信息时代,计算机以其极高的运算速度、巨大的数据存储容量,以及能准确地进行各种算术运算和逻辑运算的能力而成为现代化计算工具,并被广泛应用于社会各个领域。计算机技术的高速发展已被认为是人类进入信息时代的标志.成绩管理系统是计算机技术和信息时代的产物,是信息处理或数据处理的核心。该系统开发的总体任务是实现学生成绩管理的系统化、规范化、自动化,以达到提高学生成绩管理效率的
3、目的.通过运用程序设计软件实现学生成绩管理中的多种功能,如学生成绩信息的添加、删除、查询、修改、显示、排序等。该系统的设计充分利用计算机作为辅助工具,来实现学生考试成绩从传统的手工管理到计算机管理,并对提高管理效率和节约大量的人力、物力有一定的推动作用。因此,开发这种管理软件很必要,本文将在分析系统的应用价值以及开发工具的基础上,用C语言来开发成绩管理系统.2 系统需求分析2.1项目背景分析在我国,各大中小学校的各类信息管理系统并非一个新的课题,但也有的学校根本就没有任何信息管理系统,特别是在西部贫困地区,学校的各类管理依然由手工操作来完成,这十分落后,效率极低,成本很大,而且极异出错。随着社
4、会的发展,信息化是社会进程的必然趋势,学校管理只有快,准,精才能发挥其价值.2。2 系统开发的目标与意义(1)系统开发目标:本系统是将现代化的计算机技术和传统的教学、教务工作相结合,按照学院的工作流程设计完成的。为了使系统在学院的管理中发挥充分发挥其作用,实现工作过程的计算机化,提高工作效率和工作质量,现提出如下的系统开发目标:系统应具有实用性、可靠性和适用性.对系统中数据库的信息进行有效处理,防止数据错乱。能够按照用户选择的不同的条件进行简单查询。方便用户的操作,尽量减少用户的操作.(2)系统开发的意义:在各大中小学校,用计算机管理学校的信息已经越来越普遍了.用计算机不但可以提高工作效率,而
5、且还节省了许多人力物力财力.提高了学校的管理能力,为此,用计算机来管理学校的信息,是非常必要的。2.3 项目需求分析学校工作流程分析:学校工作总体规划由教务人员在学生成绩管理系统中输入学生的基本信息并对其进行维护管理,包括对信息的增加、修改及对信息的各项处理操作等.新的学年,教务人员首先编排班级,再对在校学生进行基本的信息录入,新生入学后由教务人员在管理系统中完成新学生信息的维护。在每个学期开始,教务处根据班级的情况,以班为单位,为每个班级安排一个班主任,并对各科老师进行安排。每举行一次考试后由任课老师对成绩进行录入。班主任对本班的成绩汇总。并进行排名,并对本年级各科成绩及总成绩进行排名.教务
6、处、班主任及任课老师跟据实际情况对录入的成绩进行维护管理,各位同学对以上录入的信息可以跟据自己的需要进行适当的查询.3 系统总体设计3。1 功能模块分析学生成绩管理系统是对学生基本信息及成绩的管理。开发工具主要采用TurboC2。0,主要用于对学生的学号、姓名等自然信息以及各项学科成绩进行增加、删除、修改、查询及保存到文件等操作。系统给用户提供了一个简单的人机界面,使用户可以根据提示输入操作项,调用系统提供的管理功能。学生成绩管理系统处理流程如图1。0主菜单界面欢迎界面1输入0退出2查询3修改4删除5插入6平均分7排序8显示继续输入10返回主菜单1学号查询2姓名查询3总分查询结 束9初始化10
7、保存返回图1 系统处理流程图主要功能设计描述如下:(1)系统主控平台允许用户选择想要的操作,包括输入学生信息、显示学生信息、查询学生信息、修改学生信息、删除学生信息、计算成绩以及成绩的排序等。通过输入相应的序号选择相应的操作.(2)学生成绩信息用户根据提示输入学生的学号、姓名、以及三门课的成绩,如语文成绩、英语成绩、数学成绩等.输入完成一条学生记录,可根据提示信息继续输入下一条学生记录或者继续其他的操作.允许输入多条学生的成绩信息记录.输入完的学生记录暂时保持在单链表中,等待下一步的操作。(3)查询学生信息可以根据学号,姓名,总分从单链表中对学生所有的信息进行查询,如果没有查询到任何信息,系统
8、会给出提示信息。(4)修改学生信息首先提示用户输入要进行修改的操作的学号,如果单链表中有该学生的信息存在,则提示用户输入要修改的学生的基本信息、各科成绩等,并将修改结果重新存储在单链表中。如果用户没有找到要修改的学生信息,系统将给出提示。(5)插入学生信息对已经建立好的信息若还需增加,则对信息进行插入.首先提示用户输入要进行插入的学号,然后在根据提示对用户信息进行完整输入.输入完成后系统将对其进行保存。(6)删除学生信息首先提示用户输入要删除学生的学号,系统根据用户输入的信息在单链表中查找,如果找到,直接删除该学生全部信息,如果没有找到,系统给出提示信息.(7)计算各科成绩平均分该模块主要进行
9、学生成绩的平均分计算,进入计算界面,系统自动对各科进行平均分计算。(8)显示学生信息在选择了显示学生信息后,将刚输入的学生信息从单链表中调出来显示,如果没有数据,则提示无学生记录。(9)学生成绩排序成绩信息输入完整后,根据学生的总分对学生从小到大进行排序,在显示学生信息的时候可以看到学生在班级或校的排列名次。(10)操作完成后对操作结果进行保存.运行完毕,退出系统。3。2 系统功能模块初始化准备3。2.1 编译预处理“编译预处理是C编译系统的一个组成部分。在C编译系统对程序进行通常的编译(包括词法和语法分析、代码生成、优化等)之前,先对程序中这些特殊命令进行“预处理,然后将预处理的结果和源程序
10、一起再进行通常的编译处理,以得到目标代码。C语言提供的预处理功能主要有:(1)宏定义;(2)文件包含;(3)条件编译.而本程序使用文件包含的预处理方式进行编译预处理:#includestdlib。h/*标准库函数/#include/*屏幕操作函数/#includestring.h/字符串函数*/3。2.2 数据结构定义学生成绩管理系统中的变量有学号,姓名,成绩等,这些数据类型各不相同,无法用简单数据类型来描述,显然要定义结构体类型。由于学生人数很多,还需要定义数组或者链表。数组的特点是数据在内存中顺序存放,长度必须事先指定,而学生的人数很难估计。如果数组长度定的过大,会找出存储空间浪费,如果过
11、小,又无法满足需求。特别是进行插入,删除等操作时,代价较大而又容易出错。用链表来管理学生成绩就显得比较妥当,它无需估计学生人数,进行插入删除等操作时代价较小。C语言中,说明和使用“结构体之前必须先定义,在编写程序之前应该对学生基本信息进行定义,在这个程序中,使用struct来定义结构体的类型为struct list,然后用它来定义变量,在定义结构体类型的时候定义一个next成员,该成员可以把学生结点进行链接。并且通过类型定义typedef将已有的各种类型名定义成为新的类型标识符link,经类型定义后,link即可当做原类型名使用。具体定义如下:struct listint ID; /学号/ch
12、arname256; /姓名/int china; /*语文成绩/int english; /英语成绩*/int math; /*数学成绩/float sum; /总分*/int order; /*排序/struct list *next; /指向下一个学生的指针/;typedef struct list node; /自定义一个数据结构的结点/typedef node *link; /定义结点为link结构*/3。3 具体模块处理函数的实现3.3.1 菜单函数界面的设计系统与用户交换的界面是通过菜单实现的,菜单按预定义格式显示主菜单界面,等待用户输入0-8中的任一数据,系统会根据用户的输入调
13、用相应的功能模块,实现用户所要求的操作.(1)本程序的菜单界面主要使用屏幕操作函数编写,欢迎界面设置为白底红字,菜单界面设置为绿底蓝字,在欢迎界面中单击任意键进入菜单操作界面。整个系统都以光标定位函数gotoxy(x,y)固定光标的位置,在对其进行输出,从而可以使显示的文字都出现在设定的窗口内,窗口的界面设置使用画图工具制作周围的边框,边框的设置具体如下:gotoxy(8,2); putch(0xc9); /输入左上角边框*/for(i=1;i46;i+) putch(0xcd); /*输出上边框水平线/putch(0xbb); /输出右上角边框*/for(i=3;i23;i+) gotoxy
14、(8,i); putch(0xba); /输出左垂直线*/gotoxy(56,i); putch(0xba); /输出右垂直线/gotoxy(8,23); putch(0xc8); /输出左下角边框/for(i=1;i46;i+) putch(0xcd); /输出下边框水平线/putch(0xbc); /输出右下角边框*/window(9,3,55,22);/制作显示菜单的窗口*/(2)菜单是由menu函数实现,主要通过printf函数显示一些文本选项如:printf(exit the program。n);构建一个简单的字符界面,系统设置11个模块,用户通过输入关键字key从010之间选择相
15、应的操作,函数通过switch调用各功能模块:switch(key) case0:exit(0);case1:head=init();break;case2:head=creat_list()break;case3:search_chengji(head);break;case4:head=modify_chengji(head,key);break;case5:head=delete_chengji(head,key);break;case6:head=insert_chengji(head,key);break;case7:average(head);break;case8:sort(he
16、ad);break;case9:printf_list(head);break;case10:save(head);break;3.3.2 功能函数设计(1)初始化链表学生成绩管理系统使用前要先将系统进行初始化操作,初始化函数init()就是将函数置空。(2)创建学生信息函数创建学习信息函数由creat_list函数实现,首先在创建链表之前先定义函数的基本信息并创建结构体指针head,pointer和new,设学号,排名为整形,名字设为字符型,语文,数学,英语成绩设为单精度类型,并对order和sum进行初始化,为head建立一个空结点,当head不为空,输入用户信息,然后将新输入的数据存于h
17、ead指针。程序如下:head=(link)malloc(sizeof(node); /建立一个新/空结点/if(head=NULL) printf(memory allocate failure!!n”); exit(0);elseprintf(please inputID:); scanf(%d,&ID); head-ID=cIDprintf(please input name:); scanf(%s”,cname);for(i=0;i256;i+) headnamei=cnamei;printf(please input china:); scanf(%d”,&cchina);headc
18、hina=cchina;headnext=NULL; pointer=head;如果输入正确既while为真的时候为news新建立一个结点,提示用户如果要继续输入按1,输入0为退出。新输入的数据存储到news指针里,然后把head和news里面的数据一起放到pointer,供下面操作时调用pointer的数据.while(1)news=(link)malloc(sizeof(node);printf(”Are you continue?”);printf(If continue enter1, or return enter0。.。”);/输入1为继续,0为退出/scanf(%d”,cID);
19、 if(cID=0)break;newsnext=NULL; pointernext=news; pointer=news;创建函数时只能创建一次,因为创建的链表暂时存于head指针里,如果再次创建,要先保存否则系统会自动将head指针进行初始化数据将被清空,存放新创建的记录。(3)查询学生成绩函数查询函数search_chengji用来对学生的基本信息进行查询。首先使用光标定位函数gotoxy(x,y)和printf函数制作查询的子菜单,菜单包括:0.exit、1.search by ID、2.search by name、3。search by sum。查询菜单设置完成后应用switch(
20、)case1:执行语句;break;语句调用相应函数操作功能。系统在调用函数时,调用自定义的辅助函数,按预定义格式显示查询成绩的子菜单界面。用户输入的格式正确时使用while函数调用相应的功能函数。 按学号查询,输入choose=1,key1为要查询的学号,查找系统中学号为key1的学生是否存在,如果key1=ID说明找到该学生,并标记flag=1,中断查询显示查询的结果,否则继续查找直到找到为止.例如:if(choose=1)while(pointer!=NULL)if(pointerIDkey1=0) flag=1;break;else pointer=pointernext; 按名字查询
21、,输入choose=2,sname为要查询学生的名字,查找系统中名字为sname的学生是否存在,如果strcmp(pointer-name,sname)=0说明找到该学生,并标记flag=1,中断查询显示查询的结果,否则继续向下查找直到找到名字为sname的学生. 按学生的总成绩查询,输入choose=3,score为要查找学生的总分,查找系统中总分为score的学生是否存在,如果if(pointersum-score=0)说明找到该学生,并标记flag=1,中断查询显示查询的结果;否则继续向下查找直到找到总分为score的学生;(4)修改学生成绩函数修改函数modify_chengji是对之
22、前所输入的信息如果出现错误,或需要更改时使用。在编写之前先对函数进行定义,并把head的值赋给pointer,然后用简单的printf函数编写修改菜单的基本界面以及修改的内容.用户根据提示输入要编辑的学号printf(”please input number for modify:”);scanf(%d,&keynum),系统根据学号查找该学生的基本信息,如果寻找到该生,系统提示要修改的具体内容,根据用户需要选择相应内容进行修改,此功能应用switch(choose)case1:执行语句;break;语句执行.printf(”enter0 exit modefiyn);printf(enter
23、1 modefiy namen);printf(enter2 modefiy chinan”);printf(enter3 modefiy englishn);printf(”enter4 modefiy mathn”);printf(Please Enter you choice:”);scanf(%d,choose);信息输入完成后,按任意键系统自动保存到pointer中,新信息将覆盖原有信息pointer-namei=xnamei,运行结束输出修改后的信息,返回到菜单。如果没有找到,系统将中止执行。while(1) if(pointerID=key3) if(choose=1) for(
24、i=0;ienglish=xenglish;break;else if(choose=4)pointermath=xmath;break; if(head!=NULL) printf(Pree any key to save!”);getch();printf_list(head);returnhead;(6)删除学生信息函数删除函数delete_chengji在编写之前先定义2个结构体pointer和q,key2为要删除学生的学号,定义完成后对pointer赋初值,用j记录pointer的位置,将其设为整形并初始化。从链表中删去一个节点只要改变链接的关系即可,既修改结点指针成员的值。从链表中
25、删除一个结点有三种情况:删除链表的头结点,删除链表的中间结点,删除链表的尾节点。具体情况如图2。. pointer!=key2时q pointer= =key2 j=0p pointer= =key2 j!=0jq=pointer;j+;pointer=pointer-next;qpp headhead.图2 删除算法当pointer的后面指针不为空: 如果key2!=pointerID,则把pointer的值赋给q,pointer指向下一个记录继续寻找学号key2。while((pointer-next!=NULL))if(pointer-ID!=key2)q=pointer; j+; po
26、inter=pointernext;else break; 如果key2=pointerID时,判断j是否为0,如果j为0说明pointer为头结点,则直接将结点删除,head指向他的下一指针.if(pointerID=key2))if(j=0)head=head-next; free(pointer); 如果判断j!=0,则说明删除的结点不是头指针,结点位于中间,要删除结点pointer首先应该让q-next指向pointernext,然后释放pointer。执行完后系统将自动停留几秒然后返回主菜单。(7)插入学生成绩插入功能主要用于插入新的学生记录。在insert_chengji函数先定义
27、2个结构体指针pointer和news,pointer为原指针,news为新插入指针。定义完成后对pointer初始化,然后为news建立新结点news=(link)malloc(sizeof(node),定义完成后为news输入新数据。插入的情况有两种既:如果pointer为空则直接将news的值赋给head输入系统并做为头指针;如果pointer不为空则把news的值赋给pointer,运行如果正确且head不为空时显示输入的数据信息。具体操作如图3。 pointer= =NULLheadp news pointer!=NULLnewsp 图3 插入算法程序:if(head!=NULL)
28、news=(link)malloc(sizeof(node); /如果head不为空,为news指针建立一个结点*/gotoxy(3,5); printf(”please input student ID:);scanf(d,news-ID);while(1) if(pointer=NULL) newsnext=head; head=news; break; /*如果pointer为空,news直接为头指针*/if(pointerID=key3) news-next=pointer-next; pointernext=news; break;/*如果key3等于ID直接插入news/point
29、er=pointer-next;(8)计算各科成绩的平均分函数计算函数average求各科的平均分.首先为各科成绩进行初始化操作,如果pointer不为空,说明里面有数据,在对其求各科的总成绩,最后在进行平均分求值.计算完成显示最后计算结果.具体程序如下:while(1) achina=achina+pointer-china; /求总分*/aenglish=aenglish+pointer-english;amath=amath+pointer-math;cnt=+cnt;if(pointer-next=NULL) break;pointer=pointernext; /求平均分*/avec
30、hina=achina/cnt;aveenglish=aenglish/cnt;avemath=amath/cnt;(9)学生成绩排序学生成绩排序函数sort用来对学生成绩进行按从大到小的顺序排序.处理过程:定义2个临时指针pointer、max,max用来存放pointer的数据,而pointer指向它的下一位。再定义一个单精度变量fen、整形变量k和字符型变量s256,分别存放成绩、学号、名字。定义完成后把先对pointer初始化,用count来记录pointer的个数,然后从1开始对max和pointer进行比较.比较一次count加1,在把count的值赋给pointer-order.
31、排序完成后到显示界面查看。函数排序过程如下:for(i=1;icount;i+) max=pointer=head;for(j=i+1;jnext;if(max-sumpointersum) /*用总分对成绩进行排名*/ fen=maxsum; maxsum=pointersum; pointersum=fen; /*总分的交换*/k=max-ID; max-ID=pointerID; pointerID=k; /学号的交换/fen=max-china; maxchina=pointer-china; pointer-china=fen; /*语文成绩的交换*/fen=max-math; ma
32、xmath=pointer-math; pointer-math=fen; /数学成绩的交换*/fen=maxenglish; max-english=pointerenglish; pointer-english=fen; /*英语成绩的交换*/strcpy(s,maxname); strcpy(maxname,pointer-name); strcpy(pointername,s);/*姓名的交换/pointer=pointernext;pointer=head; count=0;while(pointer!=NULL)/*赋排序的值*/ count+; pointer-order=cou
33、nt;pointer=pointernext;(10)显示学生成绩函数显示函数printf_list主要显示学生的基本信息,每当操作完成的时候一般都会调用此函数进行预览。printf_list函数运行时先输出表头,在单链表中反复调用函数,逐条显示学生的信息,直到运行结束,返回到主菜单界面。具体显示函数如下:printf_list(linkhead) int i=0;link pointer;clrscr(); pointer=head;gotoxy(2,4);printf(+-+-+-+-+-+-+-+n”);/显示表头/gotoxy(2,5);printf(IDname|china|engl
34、ish|mathsum|order|n”);gotoxy(2,6);printf(+-+-+-+-+-+-+n”);while(pointer!=NULL) i+;gotoxy(2,7); /*如果pointer不为空,逐条显示内容*/printf(|%d%s%4。2f|%4。2f|%4.2f|4。2f%d|n,pointer-ID,pointername,pointer-china,pointerenglish,pointer-math,pointersum,pointer-order);pointer=pointer-next; gotoxy(2,8);printf(”*end*n”);g
35、otoxy(2,10);getch();returnhead;clrscr();(11)保存学生成绩函数保存函数save主要用来对学生成绩运行后的结果进行保存。该函数在运行之前先要定义一个指向文件的指针fp,在定义一个移动指针p和保存输出的文件名outfile。用户根据系统的提示,输入要保存的文件名和保存路径。系统以只写(”w)方式打开文件,如果移动指针p不为空则写入一条记录。运行结束返回主菜单。运行过程函数:printf(”Enteroutfilename,forexamplec:f1te.txt:n);scanf(s”,outfile);fp=fopen(outfile,w”);while
36、(p!=NULL) fwrite(p,sizeof(node),1,fp);p=p-next; printf(-savesuccess!-n”);fclose(fp);4 系统测试与分析4。1 运行工具介绍C语言运用的是TurboC程序应用软件中运行。TurboC是美国Borland公司的产品,Borland公司是一家专门从事软件开发、研制的大公司。该公司相继推出了一套Turbo系列软件,如TurboBASIC,TurboPascal,TurboProlog,这些软件很受用户欢迎.该公司在1987年首次推出TurboC1.0产品,其中使用了全然一新的集成开发环境,即使用了一系列下拉式菜单,将文
37、本编辑、程序编译、连接以及程序运行一体化,大大方便了程序的开发。1988年,Borland公司又推出TurboC1。5版本,增加了图形库和文本窗口函数库等,而TurboC2。0则是该公司1989年出版的.TurboC2.0在原来集成开发环境的基础上增加了查错功能,并可以在Tiny模式下直接生成。COM(数据、代码、堆栈处在同一64K内存中)文件。还可对数学协处理器(支持8087/80287/80387等)进行仿真。4。2 系统操作将编写好的程序在TurboC的代码编辑器里进行编辑,语法检查正确后进行运行。系统进入运行后,首先进入系统欢迎界面单击任意键键进入学生成绩管理系统的主菜单界面,系统提示
38、用户输入0-8之间的不同数字,来实现不同的操作。主菜单界面如图4所示。图4 学生成绩管理主菜单界面进入主菜单界面后,输入数字1对本系统先进行初始化,初始化后并可以输入2进去创建界面,用户可以根据提示信息输入学生的基本信息,输入完一条后,若要继续输入则输入1,否则退出输入0,输入完成后调用显示功能模块,供用户预览。创建的时候只能创建一次,反复创建将把之前的数据清空,如需增加数据则使用插入功能.运行结束返回主菜单界面。若要进行查询,在主菜单中输入3,则进入查询学生信息的子菜单,用户可以根据自己的喜欢选择用学号,姓名,总分中任一方式查询.根据系统提示信息输入查询的条件,如果要查找的学生存在,系统根据
39、要求从数据库中查找到该学生的信息,并输出显示.否则提示没有找到信息,返回主菜单界面。查询学生信息子菜单界面如图5所示。图5 查询信息若要对学生信息进行修改则在主菜单中输入4,进入修改学生信息界面,根据系统提示信息输入要修改学生的学号,系统根据输入的学号,检索要修改的学生信息,在根据显示的内容,选择要修改的具体内容。修改完成先显示未修改的信息,单击任一键对其进行保存。若要删除学生信息,在主菜单中输入5,进入删除学生信息界面,输入要删除的学生学号,如果该学号存在,系统将自动将其学生信息删除,如果不存在,则显示提示说明没有该学号学生。操作完成后删除界面停留几秒立即返回到主菜单界面。在主菜单中若输入的
40、是6,则进入插入学生信息界面,根据系统提示信息输入要增加的学生学号,若此学号不存在则根据提示输入学生的基本信息,输入完成后系统会自动保存.在主菜单中若输入7,则进入计算各科平均分成绩,计算完成输出计算结果.在主菜单界面中如果输入8,则进入学生成绩排行界面,系统会自动将刚输入学生的成绩进行排列,通过显示功能模块输出学生的排名。在主菜单界面中如果输入9,则进入显示学生信息界面,系统会将刚输入的学生的信息按照预定格式显示出来。在主菜单中如果如果10,对其操作内容进行保存。退出系统输入0。结束语本文简要介绍了如何用C语言来编写学生成绩管理系统和设计过程中的一些主要步骤.本系统基本上能够实现学生成绩管理
41、的添加、删除、查询、修改、计算、显示、排序等功能,但是在设计过程中还有些功能不是很完善,操作界面不美观,还有非常多地方需要以后继续改进。因此在以后的学习当中还应该更加努力,尽量达到最好。参考文献:1 梁旭,古晓琳,黄明编著。C语言课程设计(第2版).电子工业出版社,2009.8.2 毕万新,景福文主编。C语言程序设计(第四版).大连理工大学出版社,2005.8。3 田淑清主编.全国计算机等级考试二级教程。C语言程序设计(2008年版)。北京:高等教育出版社,2007。8.4 (美)罗伯茨(Roberts,E,S)著,翁惠玉等译.C语言的科学和艺术.北京:机械工业出版社,2005.3.5 齐景嘉主编,陈炯,张三群,苗树红编。数据结构(含实训)。南京:东南大学出版社,2006。6.6 王晓东主编。C程序设计简明教程.北京:中国水利水电出版社,2006(2007重印)。7 张宗杰主编.C语言程序设计使用教材.北京:电子工业出版社,2008.1.
©2010-2024 宁波自信网络信息技术有限公司 版权所有
客服电话:4008-655-100 投诉/维权电话:4009-655-100