求关于(程序设计)学生信息成绩管理的报告格式(只按要求就行)

求关于(程序设计)学生信息成绩管理的报告格式(只按要求就行),第1张

C语言课程设计任务书

一、题目: 学生成绩管理

二、目的与要求

1. 目的:

(1)基本掌握面向过程程序设计的基本思路和方法;

(2)达到熟练掌握C语言的基本知识和技能;

(3)能够利用所学的基本知识和技能,解决简单的程序设计问题

2. 要求

基本要求:

1. 要求利用C语言面向过程的编程思想来完成系统的设计;

2. 突出C语言的函数特征,以多个函数实现每一个子功能;

3. 画出功能模块图;

4. 进行简单界面设计,能够实现友好的交互;

5. 具有清晰的程序流程图和数据结构的详细定义;

6. 熟练掌握C语言对文件的各种 *** 作。

创新要求:

在基本要求达到后,可进行创新设计,如系统用户功能控制,对管理员级和一般级别的用户系统功能 *** 作不同

三、信息描述

输入一个班10个学生的学号和每个学生考试三门功课(数学、英语、计算机基础)的成绩。编程计算出每个学生的总分和平均分,并按学生成绩优劣排序,最后打印一张按高分到低分名次排序的成绩单。要求:

1)排序用一个函数实现。

2)打印的成绩单表项包括:序号,学号、数学、英语、计算机、总分、平均分。

3)按实验报告电子模板格式填写实验内容。

四、功能描述

1. 学生基本信息及成绩所选科目成绩的录入。

2. 基本信息的查询(分系、班级;分科目)与修改。

3. 对每系或每班各科成绩进行分析(即求单科平均成绩、及格率和优秀率);

4. 对所开课程的成绩分析(求其平均成绩,最高分和最低分);

5. 对学生考试成绩进行排名(单科按系别或班级进行排名,对每一个班级,同一学期学生总体成绩进行排名,并显示各科成绩信息)

五、解决方案

1. 分析程序的功能要求,划分程序功能模块。

2. 画出系统流程图。

3. 代码的编写。定义数据结构和各个功能子函数。

4. 程序的功能调试。

5. 完成系统总结报告以及使用说明书

六、进度安排

此次课程设计时间为两周,分四个阶段完成:

1. 分析设计阶段。指导教师应积极引导学生自主学习和钻研问题,明确设计要求,找出实现方法,按照需求分析、总体设计、详细设计这几个步骤进行。

2. 编码调试阶段:根据设计分析方案编写C代码,然后调试该代码,实现课题要求的功能。

3. 总结报告阶段:总结设计工作,写出课程设计说明书,要求学生写出需求分析、总体设计、详细设计、编码、测试的步骤和内容。

4. 考核阶段。

#include <stdio.h>

#include <stdlib.h>

#define STU_NUM 10 /*宏定义学生的数量*/

struct student /*定义一个结构体用来存放学生学号、三门课成绩、总分及平均成绩*/

{

char stu_id[20]/*学生学号;*/

float score[3]/*三门课成绩;*/

float total/*总成绩;*/

float aver/*平均成绩;*/

}

/*排序用一个函数来实现*/

void SortScore(student *stu,int n)

{

student stud

for(int i = 0i <n-1i++)

for(int j = i+1 j <nj++)

{

if(stu[i].total <stu[j].total)

{

stud = stu[i]

stu[i] = stu[j]

stu[j] = stud

}

}

}

int main( )

{

student stu[STU_NUM]/*创建结构体数组中有10个元素,分别用来保存这10个人的相关信息。*/

/*输入这十个学生的相关信息*/

for(int i = 0i<STU_NUMi++)

{

printf("请输入第%d个学生的学号:",i+1)

scanf("%s",&stu[i].stu_id)

printf("输入第%d个学生的数学成绩:",i+1)

scanf("%f",&stu[i].score[0])

printf("输入第%d个学生的英语成绩:",i+1)

scanf("%f",&stu[i].score[1])

printf("输入第%d个学生的计算机成绩:",i+1)

scanf("%f",&stu[i].score[2])

stu[i].total = stu[i].score[0]+stu[i].score[1]+stu[i].score[2]

stu[i].aver = stu[i].total/3

}

printf("\n")

SortScore(stu,STU_NUM)/*调用排序函数*/

/*输出排序后的各学生的成绩*/

for(i = 0 i <STU_NUMi++)

{

printf("序号: %d\t",i)

printf("学号:%s\t",stu[i].stu_id)

printf("数学:%f\t",stu[i].score[0])

printf("英语:%f\t",stu[i].score[1])

printf("计算机:%f\t",stu[i].score[2])

printf("平均成绩:%f\t",stu[i].aver)

printf("总分:%f\t",stu[i].total)

printf("\n\n")

}

return 0

}

注:(源程序中主要标识符含义说明)

#define STU_NUM 10 /*宏定义学生的数量*/

struct student /*定义一个结构体用来存放学生学号、三门课成绩、总分及平均成绩*/

{

char stu_id[20]/*学生学号;*/

float score[3]/*三门课成绩;*/

float total/*总成绩;*/

float aver/*平均成绩;*/

}

实验结果:

输入 :(只输入后面的数字,前面的文字是自己产生的)。

请输入第1个学生的学号:001

输入第1个学生的数学成绩:1

输入第1个学生的英语成绩:1

输入第1个学生的计算机成绩:1

请输入第2个学生的学号:002

输入第2个学生的数学成绩:2

输入第2个学生的英语成绩:2

输入第2个学生的计算机成绩:2

请输入第3个学生的学号:003

输入第3个学生的数学成绩:3

输入第3个学生的英语成绩:3

输入第3个学生的计算机成绩:3

请输入第4个学生的学号:004

输入第4个学生的数学成绩:4

输入第4个学生的英语成绩:4

输入第4个学生的计算机成绩:4

请输入第5个学生的学号:005

输入第5个学生的数学成绩:5

输入第5个学生的英语成绩:5

输入第5个学生的计算机成绩:5

请输入第6个学生的学号:006

输入第6个学生的数学成绩:6

输入第6个学生的英语成绩:6

输入第6个学生的计算机成绩:6

请输入第7个学生的学号:007

输入第7个学生的数学成绩:7

输入第7个学生的英语成绩:7

输入第7个学生的计算机成绩:7

请输入第8个学生的学号:008

输入第8个学生的数学成绩:8

输入第8个学生的英语成绩:8

输入第8个学生的计算机成绩:8

请输入第9个学生的学号:009

输入第9个学生的数学成绩:9

输入第9个学生的英语成绩:9

输入第9个学生的计算机成绩:9

请输入第10个学生的学号:010

输入第10个学生的数学成绩:10

输入第10个学生的英语成绩:10

输入第10个学生的计算机成绩:10

输出:

序号: 0 学号:010 数学:10.000000 英语:10.000000 计算机:10.000000

平均成绩:10.000000 总分:30.000000

序号: 1 学号:009 数学:9.000000 英语:9.000000 计算机:9.000000

平均成绩:9.000000 总分:27.000000

序号: 2 学号:008 数学:8.000000 英语:8.000000 计算机:8.000000

平均成绩:8.000000 总分:24.000000

序号: 3 学号:007 数学:7.000000 英语:7.000000 计算机:7.000000

平均成绩:7.000000 总分:21.000000

序号: 4 学号:006 数学:6.000000 英语:6.000000 计算机:6.000000

平均成绩:6.000000 总分:18.000000

序号: 5 学号:005 数学:5.000000 英语:5.000000 计算机:5.000000

平均成绩:5.000000 总分:15.000000

序号: 6 学号:004 数学:4.000000 英语:4.000000 计算机:4.000000

平均成绩:4.000000 总分:12.000000

序号: 7 学号:003 数学:3.000000 英语:3.000000 计算机:3.000000

平均成绩:3.000000 总分:9.000000

序号: 8 学号:002 数学:2.000000 英语:2.000000 计算机:2.000000

平均成绩:2.000000 总分:6.000000

序号: 9 学号:001 数学:1.000000 英语:1.000000 计算机:1.000000

平均成绩:1.000000 总分:3.000000

七、撰写课程设计报告或课程设计总结

课程设计报告要求:

总结报告包括需求分析、总体设计、详细设计、编码(详细写出编程步骤)、测试的步骤和内容、课程设计总结、参考资料等,不符合以上要求者,则本次设计以不及格记。

C语言常见错误

书写标识符时,忽略了大小写字母的区别

main()

{

int a=5

printf("%d",A)

}

编译程序把a和A认为是两个不同的变量名,而显示出错信息。C认为大写字母和小写字母是两个不同的字符。习惯上,符号常量名用大写,变量名用小写表示,以增加可读性。

2.忽略了变量的类型,进行了不合法的运算。

main()

{

float a,b

printf("%d",a%b)

}

%是求余运算,得到a/b的整余数。整型变量a和b可以进行求余运算,而实型变量则不允许进行“求余”运算。

3.将字符常量与字符串常量混淆。

char c

c="a"

在这里就混淆了字符常量与字符串常量,字符常量是由一对单引号括起来的单个字符,字符串常量是一对双引号括起来的字符序列。C规定以“\”作字符串结束标志,它是由系统自动加上的,所以字符串“a”实际上包含两个字符:‘a'和‘\',而把它赋给一个字符变量是不行的。

4.忽略了“=”与“==”的区别。

在许多高级语言中,用“=”符号作为关系运算符“等于”。如在BASIC程序中可以写

if (a=3) then …

但C语言中,“=”是赋值运算符,“==”是关系运算符。如:

if (a==3) a=b

前者是进行比较,a是否和3相等,后者表示如果a和3相等,把b值赋给a。由于习惯问题,初学者往往会犯这样的错误。

5.忘记加分号。

分号是C语句中不可缺少的一部分,语句末尾必须有分号。

a=1

b=2

编译时,编译程序在“a=1”后面没发现分号,就把下一行“b=2”也作为上一行语句的一部分,这就会出现语法错误。改错时,有时在被指出有错的一行中未发现错误,就需要看一下上一行是否漏掉了分号。

{ z=x+y

t=z/100

printf("%f",t)

}

对于复合语句来说,最后一个语句中最后的分号不能忽略不写(这是和PASCAL不同的)。

6.多加分号。

对于一个复合语句,如:

{ z=x+y

t=z/100

printf("%f",t)

}

复合语句的花括号后不应再加分号,否则将会画蛇添足。

又如:

if (a%3==0)

I++

本是如果3整除a,则I加1。但由于if (a%3==0)后多加了分号,则if语句到此结束,程序将执行I++语句,不论3是否整除a,I都将自动加1。

再如:

for (I=0I<5I++)

{scanf("%d",&x)

printf("%d",x)}

本意是先后输入5个数,每输入一个数后再将它输出。由于for()后多加了一个分号,使循环体变为空语句,此时只能输入一个数并输出它。

7.输入变量时忘记加地址运算符“&”。

int a,b

scanf("%d%d",a,b)

这是不合法的。Scanf函数的作用是:按照a、b在内存的地址将a、b的值存进去。“&a”指a在内存中的地址。

8.输入数据的方式与要求不符。①scanf("%d%d",&a,&b)

输入时,不能用逗号作两个数据间的分隔符,如下面输入不合法:

3,4

输入数据时,在两个数据之间以一个或多个空格间隔,也可用回车键,跳格键tab。

②scanf("%d,%d",&a,&b)

C规定:如果在“格式控制”字符串中除了格式说明以外还有其它字符,则在输入数据时应输入与这些字符相同的字符。下面输入是合法的:

3,4

此时不用逗号而用空格或其它字符是不对的。

3 4 3:4

又如:

scanf("a=%d,b=%d",&a,&b)

输入应如以下形式:

a=3,b=4

9.输入字符的格式与要求不一致。

在用“%c”格式输入字符时,“空格字符”和“转义字符”都作为有效字符输入。

scanf("%c%c%c",&c1,&c2,&c3)

如输入a b c

字符“a”送给c1,字符“ ”送给c2,字符“b”送给c3,因为%c只要求读入一个字符,后面不需要用空格作为两个字符的间隔。

10.输入输出的数据类型与所用格式说明符不一致。

例如,a已定义为整型,b定义为实型

a=3b=4.5

printf("%f%d\n",a,b)

编译时不给出出错信息,但运行结果将与原意不符。这种错误尤其需要注意。

11.输入数据时,企图规定精度。

scanf("%7.2f",&a)

这样做是不合法的,输入数据时不能规定精度。

12.switch语句中漏写break语句。

例如:根据考试成绩的等级打印出百分制数段。

switch(grade)

{ case 'A':printf("85~100\n")

case 'B':printf("70~84\n")

case 'C':printf("60~69\n")

case 'D':printf("<60\n")

default:printf("error\n")

由于漏写了break语句,case只起标号的作用,而不起判断作用。因此,当grade值为A时,printf函数在执行完第一个语句后接着执行第二、三、四、五个printf函数语句。正确写法应在每个分支后再加上“break”。例如

case 'A':printf("85~100\n")break

13.忽视了while和do-while语句在细节上的区别。

(1)main()

{int a=0,I

scanf("%d",&I)

while(I<=10)

{a=a+I

I++

}

printf("%d",a)

}

(2)main()

{int a=0,I

scanf("%d",&I)

do

{a=a+I

I++

}while(I<=10)

printf("%d",a)

}

可以看到,当输入I的值小于或等于10时,二者得到的结果相同。而当I>10时,二者结果就不同了。因为while循环是先判断后执行,而do-while循环是先执行后判断。对于大于10的数while循环一次也不执行循环体,而do-while语句则要执行一次循环体。

14.定义数组时误用变量。

int n

scanf("%d",&n)

int a[n]

数组名后用方括号括起来的是常量表达式,可以包括常量和符号常量。即C不允许对数组的大小作动态定义。

15.在定义数组时,将定义的“元素个数”误认为是可使的最大下标值。

main()

printf("%d",a[10])

}

C语言规定:定义时用a[10],表示a数组有10个元素。其下标值由0开始,所以数组元素a[10]是不存在的。

16.初始化数组时,未使用静态存储。

int a[3]=

这样初始化数组是不对的。C语言规定只有静态存储(static)数组和外部存储(exterm)数组才能初始化。应改为:

static int a[3]=

17.在不应加地址运算符&的位置加了地址运算符。

scanf("%s",&str)

C语言编译系统对数组名的处理是:数组名代表该数组的起始地址,且scanf函数中的输入项是字符数组名,不必要再加地址符&。应改为:

scanf("%s",str)

18.同时定义了形参和函数中的局部变量。

int max(x,y)

int x,y,z

{z=x>y?x:y

return(z)

}

形参应该在函数体外定义,而局部变量应该在函数体内定义。应改为:

int max(x,y)

int x,y

{int z

z=x>y?x:y

return(z)

}

C语言心得体会

通过这次实训,增加了我学习软件技术的兴趣,虽然还不明确软件技术包含的具体内容,但从C语言这门课程开始,已发现程序设计的乐趣,在学习C语言的过程中也学到了许多计算机应用基础知识,对计算机的机体也有了一个大体的了解。

这次实训是老师给了范例程序,经过自己的改写,实现要求。先做简单的输出,一步步的再做其它图案,在实际 *** 作过程中犯的一些错误还会有意外的收获,感觉实训很有意思。在具体 *** 作中对这学期所学的C语言的理论知识得到巩固,达到实训的基本目的,也发现自己的不足之出,在以后的上机中应更加注意,同时体会到C语言具有的语句简洁,使用灵活,执行效率高等特点。发现上机实训的重要作用,特别是对数组和循环有了深刻的理解。

通过实际 *** 作,学会 C语言程序编程的基本步骤、基本方法,开发了自己的逻辑思维能力,培养了分析问题、解决问题的能力。深刻体会到“没有做不到的,只有想不到的”,“团结就是力量”,“实践是检验真理的标准”,“不耻下问”……的寓意。

计时在此希望以后应多进行这样的实训,加长设间,培养学生独立思考问题的能力,提高实际 *** 作水平。

八、参考资料 :《C语言程序设计教程》

#include"stdio.h"

#include"stdlib.h"

#include"string.h"

#include"conio.h"

#define HEADER1 " --------------------------------STUDENT------------------------------ \n"

#define HEADER2 " | number| name |Comp|Math|Eng | sum | ave |mici| \n"

#define HEADER3 " |---------------|---------------|----|----|----|--------|--------|----| "

#define FORMAT "| %-10s|%-15s|%3d |%3d |%3d | %3d | %-6.2f |%3d |\n"

#define DATA p->data.num,p->data.name,p->data.egrade,p->data.mgrade,p->data.cgrade,p->data.total,p->data.ave,p->data.mingci

#define END " --------------------------------------------------------------------- \n"

typedef struct student

{

char num[10]

char name[15]

int cgrade

int mgrade

int egrade

int total

float ave

int mingci

}

typedef struct node

{

struct student data

struct node *next

}Node,*Link

void menu()

void printfdata(Node *)

void printfheader()

void Wrong()

void Notfind()

void Disp(Link)

void stringinput(char *,int,char *)

Node * Locate(Link,char *, char *)

void Add(Link)

void Qur(Link)

void Del(Link)

void Modify(Link)

void Insert(Link)

void Tongji(Link)

void Sort(Link)

void Save(Link)

int numerinput(char *)

void printfheader()

int saveflag=0

void menu()

{

system("cls")

printf("\n")

printf("|******************************************************************************|\n")

printf("|*\x3 1: input record\x3 2: delete record*|\n")

printf("|*\x3 3: search record\x3 4: modify record*|\n")

printf("|*\x3 5: insert record\x3 6: count record*|\n")

printf("|*\x3 7: sortrecord\x3 8: save record*|\n")

printf("|*\x3 9: display record\x3 0: quit system*|\n")

printf("|******************************************************************************|\n")

}

void printfdata(Node *pp)

{

Node *p

p=pp

printf(FORMAT,DATA)

}

void printfheader()

{

printf(HEADER1)

printf(HEADER2)

printf(HEADER3)

}

void Wrong()

{

printf("\n\n\n\n\n\n\n************ERROR:input has wrong ! press any key to continue*************\n")

getchar()

}

void Notfind()

{

printf("\n==>Not find this student !\n")

}

void Disp(Link l)

{

Node *p

p=l->next

if(!p)

{

printf("\n==>Not student record !\n")

getchar()

return

}

printf("\n\n")

printfheader()

while(p)

{

printfdata(p)

p=p->next

printf(HEADER3)

}

getchar()

}

void stringinput(char *t,int lens,char *notice)

{

char n[255]

do{

printf(notice)

scanf("%s",n)

if(strlen(n)>lens)

printf("\n exceed the requird length!\n")

}while(strlen(n)>lens)

strcpy(t,n)

}

int numberinput(char *notice)

{

int t=0

do{

printf(notice)

scanf("%d",&t)

if(t>100 || t<0)

printf("\n score must in [0~100] !\n")

}while(t>100 || t<0)

return t

}

Node* Locate(Link l,char findness[],char nameornum[])

{

Node *r

if(strcmp(nameornum,"num")==0)

{

r=l->next

while(r)

{

if(strcmp(r->data.num,findness)==0)

return r

r=r->next

}

}

else if(strcmp(nameornum,"name")==0)

{

r=l->next

while(r)

{

if(strcmp(r->data.name,findness)==0)

return r

r=r->next

}

}

return 0

}

void Add(Link l)

{

Node *p,*r,*s

char ch,flag=0,num[10]

r=l

s=l->next

system("cls")

Disp(l)

while(r->next!=NULL)

r=r->next

while(1)

{

while(1)

{

stringinput(num,10,"input number(press '0' return menu):")

flag=0

if(strcmp(num,"0")==0)

{

return

}

s=l->next

while(s)

{

if(strcmp(s->data.num,num)==0)

{

flag=1

break

}

s=s->next

}

if(flag==1)

{

getchar()

printf("==>The number %s is not existing,try again?(y/n):",num)

scanf("%c",&ch)

if(ch=='y'||ch=='Y')

continue

else

return

}

else

{

break

}

}

p=(Node*)malloc(sizeof(Node))

if(!p)

{

printf("\n allocate memory failure ")

return

}

strcpy(p->data.num,num)

stringinput(p->data.name,15,"Name:")

p->data.cgrade=numberinput("C language Score[0~100]:")

p->data.mgrade=numberinput("Math Score[0~100]:")

p->data.egrade=numberinput("English Score[0~100]:")

p->data.total=p->data.cgrade+p->data.mgrade+p->data.mgrade

p->data.ave=p->data.total/3.0

p->data.mingci=0

p->next=NULL

r->next=p

r=p

saveflag=1

}

return

}

void Del(Link l)

{

int sel

Node *p,*r

char findmess[20]

if(!l->next)

{

system("cls")

printf("\n==>No student record!\n")

getchar()

return

}

system("cls")

Disp(l)

printf("\n==>1 Delete by number ==>2 Delete by name\n")

printf(" please choice [1,2]:")

scanf("%d",&sel)

if(sel==1)

{

stringinput(findmess,10,"input the existing student number:")

p=Locate(l,findmess,"num")

if(p)

{

r=l

while(r->next!=p)

r=r->next

r->next=p->next

free(p)

printf("\n==>delete success!\n")

getchar()

saveflag=1

}

else

Notfind()

getchar()

}

else if(sel==2)

{

stringinput(findmess,15,"input the existing student name:")

p=Locate(l,findmess,"name")

if(p)

{

r=l

while(r->next!=p)

r=r->next

r->next=p->next

free(p)

printf("\n==>delete success !\n")

getchar()

saveflag=1

}

else

Notfind()

getchar()

}

else

Wrong()

getchar()

}

void Qur(Link l)

{

int select

char searchinput[20]

Node *p

if(!l->next)

{

system("cls")

printf("\n==>No student record!\n")

getchar()

return

}

system("cls")

printf("\n==>1 Search by number 2 Search by name\n")

printf(" Please choice[1~2]:")

scanf("%d",&select)

if(select==1)

{

stringinput(searchinput,10,"input the existing student number:")

p=Locate(l,searchinput,"num")

if(p)

{

printfheader()

printfdata(p)

printf(END)

printf("press any key to return .")

getchar()

}

else

Notfind()

getchar()

}

else if(select=2)

{

stringinput(searchinput,15,"input the existing student name:")

p=Locate(l,searchinput,"name")

if(p)

{

printfheader()

printfdata(p)

printf(END)

printf("Press any key to return.")

getchar()

}

else

Notfind()

getchar()

}

else

Wrong()

getchar()

}

void Modify(Link l)

{

Node *p

char findmess[20]

if(!l->next)

{

system("cls")

printf("\n==>No student record!\n")

getchar()

return

}

system("cls")

printf("modify student recorder.")

Disp(l)

stringinput(findmess,10,"input the existing student number:")

p=Locate(l,findmess,"num")

if(p)

{

printf("Number : %s,\n",p->data.num)

printf("Name :%s,\n",p->data.name)

stringinput(p->data.name,15,"input new name:")

printf("C language score :%d,\n",p->data.cgrade)

p->data.cgrade=numberinput("C language Score[0~100]:")

printf("Math score :%d,\n",p->data.mgrade)

p->data.mgrade=numberinput("Math Score[0~100]:")

printf("English score :%d,\n",p->data.egrade)

p->data.egrade=numberinput("English Score [0~100]:")

p->data.total=p->data.cgrade+p->data.mgrade+p->data.mgrade

p->data.ave=p->data.total/3.0

p->data.mingci=0

printf("\n==>modify success !\n")

Disp(l)

saveflag=1

}

else

Notfind()

getchar()

}

void Insert(Link l)

{

Link p,v,newinfo

char ch,num[10],s[10]

int flag=0

v=l->next

system("cls")

Disp(l)

while(1)

{

stringinput(s,10,"please input insert location after the Number :")

flag=0

v=l->next

while(v)

{

if(strcmp(v->data.num,s)==0)

{

flag=1

break

}

v=v->next

}

if(flag==1)

break

else

{

getchar()

printf("\n==>The number %s is not existing ,try again?(y/n):",s)

scanf("%c",&ch)

if(ch=='y'||ch=='Y')

continue

else

return

}

}

stringinput(num,10,"input new student Number:")

v=l->next

while(v)

{

if(strcmp(v->data.num,num)==0)

{

printf("==>Sorry , The new number:'%s' is existing!\n",num)

printfheader()

printfdata(v)

printf("\n")

getchar()

return

}

v=v->next

}

newinfo=(Node *)malloc(sizeof(Node))

if(!newinfo)

{

printf("\n allocate memory failure ")

return

}

strcpy(newinfo->data.num,num)

stringinput(newinfo->data.name,15,"Name:")

newinfo->data.cgrade=numberinput("C language Score[0~100]:")

newinfo->data.mgrade=numberinput("Math Score[0~100]:")

newinfo->data.egrade=numberinput("English Score[0~100]:")

newinfo->data.total=newinfo->data.cgrade+newinfo->data.mgrade+newinfo->data.mgrade

newinfo->data.ave=newinfo->data.total/3.0

newinfo->data.mingci=0

newinfo->next=NULL

saveflag=1

p=l->next

while(1)

{

if(strcmp(p->data.num,s)==0)

{

newinfo->next=p->next

p->next=newinfo

break

}

p=p->next

}

Disp(l)

printf("\n\n")

getchar()

}

void Tongji(Link l)

{

Node *pm,*pe,*pc,*pt

Node *r=l->next

int countc=0,countm=0,counte=0

if(!r)

{

system("cls")

printf("\n==>Not student record!\n")

getchar()

return

}

system("cls")

Disp(l)

pm=pe=pt=r

while(r)

{

if(r->data.cgrade<60) countc++

if(r->data.mgrade<60) countm++

if(r->data.egrade<60) counte++

if(r->data.cgrade>pc->data.cgrade) pc=r

if(r->data.mgrade>pm->data.mgrade) pm=r

if(r->data.egrade>pe->data.egrade) pe=r

if(r->data.total>pt->data.total) pt=r

r=r->next

}

printf("\n---------------------------------The Tongji Result-----------------------------\n")

printf("C Language<60:%d(ren)\n",countc)

printf("Math <60:%d(ren)\n",countm)

printf("English <60:%d(ren)\n",counte)

printf("---------------------------------------------------------------------------------\n")

printf("The highest student by total score name:%s total score:%d\n",pt->data.name,pt->data.total)

printf("The highest student by English score name:%s total score:%d\n",pe->data.name,pe->data.egrade)

printf("The highest student by Math score name:%s total score:%d\n",pm->data.name,pm->data.mgrade)

printf("The highest student by C language score:%s total score:%d\n",pc->data.name,pc->data.cgrade)

printf("\n\nPress any key to return .")

getchar()

}

void Sort(Link l)

{

Link ll

Node *p,*rr,*s

int i=0

if(l->next==NULL)

{

system("cls")

printf("\n==>Not student record!\n")

getchar()

return

}

ll=(Node*)malloc(sizeof(Node))

if(!ll)

{

printf("\n allocate memory failure")

return

}

ll->next=NULL

system("cls")

Disp(l)

p=l->next

while(p)

{

s=(Node*)malloc(sizeof(Node))

if(!s)

{

printf("\n allocate memory failure ")

return

}

s->data=p->data

s->next=NULL

rr=ll

while(rr->next!=NULL &&rr->next->data.total>=p->data.total)

{

rr=rr->next

}

if(rr->next==NULL)

rr->next=s

else

{

s->next=rr->next

rr->next=s

}

p=p->next

}

l->next=ll->next

p=l->next

while(p!=NULL)

{

i++

p->data.mingci=i

p=p->next

}

Disp(l)

saveflag=1

printf("\n ==>sort coplate!\n")

}

void Save(Link l)

{

FILE *fp

Node *p

int count=0

fp=fopen("e:\\student.tex","wb")

if(fp==NULL)

{

printf("\n==>open file error!\n")

getchar()

return

}

p=l->next

while(p)

{

if(fwrite(p,sizeof(Node),1,fp)==1)

{

p=p->next

count++

}

else

break

}

if(count>0)

{

getchar()

printf("\n\n\n\n==>save file complete,total save's record number is:%d\n",count)

getchar()

saveflag=0

}

else

{

system("cls")

printf("the current link us empty,no student record is saved!\n")

getchar()

}

fclose(fp)

}

void main()

{

Link l

FILE *fp

int select

char ch

int count=0

Node *p,*r

l=(Node*)malloc(sizeof(Node))

if(!l)

{

printf("\n allocate memory failure!")

return

}

l->next=NULL

r=l

fp=fopen("e:\\student.tex","ab+")

if(fp==NULL)

{

printf("\n===>can not open file!\n")

exit(0)

}

while(!feof(fp))

{

p=(Node *)malloc(sizeof(Node))

if(!p)

{

printf("memory malloc failure!\n")

exit(0)

}

if(fread(p,sizeof(Node),1,fp)==1)

{

p->next=NULL

r->next=p

r=p

count++

}

}

fclose(fp)

printf("\n==>open file success , the total records numbers is :%d.\n",count)

menu()

while(1)

{

system("cls")

menu()

p=r

printf("\n please Enter your choice(0~9):")

scanf("%d",&select)

if(select==0)

{

if(saveflag==1)

{

getchar()

printf("\n==>Whether save the modified record to file ?(y/n):\n")

scanf("%c",&ch)

if(ch=='y'||ch=='Y')

Save(l)

}

printf("==>thank you for your useness!")

getchar()

break

}

switch(select)

{

case 1:Add(l)break

case 2:Del(l)break

case 3:Qur(l)break

case 4:Modify(l)break

case 5:Insert(l)break

case 6:Tongji(l)break

case 7:Sort(l)break

case 8:Save(l)break

case 9:system("cls")Disp(l)break

default:Wrong()getchar()break

}

}

}

如果学了数据结构就很好办了,可以使用动态链表,虽然这个程序看起来很难,但用模块化编程,每个函数最多也就几十行的样子,总共两三百行吧。。我写过,不过不在我这台电脑里,既然是设计报告,就得自己下功夫琢磨,那样写出的代码才有价值。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/9661974.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-30
下一篇 2023-04-30

发表评论

登录后才能评论

评论列表(0条)

保存