当前位置:首页 » 考试成绩 » 假设有张学生成绩表

假设有张学生成绩表

发布时间: 2021-01-18 07:47:07

㈠ 假设收集到了一个班学生的所有成绩信息(不低于20人),要求用C语言编写一个简单的成绩管理系统

代码已发,在附件,邮件名“代码”,附件Untitled2.c

如果有疑问欢迎追问。

代码如下:

#include<stdio.h>

#include<string.h>

#include<malloc.h>

#include<math.h>

#define min(A,B) (A<B?A:B)

#define max(A,B) (A<B?B:A)

typedef struct Student

{

long long int id;

char name[11];

int score[4];

double avg;

struct Student* next;

} Student;

void print(Student* stu)

{

printf("学号:%10lld 姓名:%10s 成绩:语文:%3d 数学:%3d 英语:%3d 计算机:%3d 平均分:%3.2lf ",

stu->id,stu->name,stu->score[0],stu->score[1],stu->score[2],stu->score[3],stu->avg);

}

int main(void)

{

Student* head = 0;


int stucount=0;//数量


while(1)

{

printf("输入操作号:1:录入学生 2:浏览 3:查询 4:修改 5:排序 6:统计 ");


int quest;

scanf("%d",&quest);

scanf("%*[^ ]");


if(quest==1)

{

printf("录入学生: ") ;

while(1)

{

printf("请输入学生学号(-1退出录入): ");

long long int id;

scanf("%lld", &id);


if(id==-1)break;


Student* newStudent = (Student*)malloc(sizeof(Student));

newStudent->id=id;


printf("请输入学生名字: ");

scanf("%10s", newStudent->name);

scanf("%*[^ ]");


printf("请输入学生语文成绩: ");

scanf("%d",&(newStudent->score[0]));


printf("请输入学生数学成绩: ");

scanf("%d",&(newStudent->score[1]));


printf("请输入学生英语成绩: ");

scanf("%d",&(newStudent->score[2]));


printf("请输入学生计算机成绩: ");

scanf("%d",&(newStudent->score[3]));


int sum=0;

for(int i=0; i<4; ++i)sum+=newStudent->score[i];

newStudent->avg = sum/4.0;

printf("学生已录入!平均分为:%lf ",newStudent->avg);


//插入链表首,这样最新添加的显示在最上面,容易看见效果

newStudent->next=head;

head=newStudent;


++stucount;

}



}

else if(quest==2)

{

if(head==0)

printf("没有学生! ");

else

{

printf("开始浏览学生: ");

int st=0,en=min(st+10,stucount);

while(1)

{

printf("浏览学生:%d个到%d个学生 ",st+1,en);

Student* stu = head;

for(int i=0; i<st; ++i)

{

stu=stu->next;

}

for(int i=st; i<en; ++i)

{

print(stu);

stu=stu->next;

}

printf("输入操作号:1 向后翻页;2 向前翻页;-1 退出 ");

int squest;

scanf("%d",&squest);

scanf("%*[^ ]");

if(squest==1)

{

if(en!=stucount) st=en;

}

else if(squest==2)

{

st=max(0,st-10);

}

else if(squest==-1)break;

en=min(st+10,stucount);

}

}

}

else if(quest==3)

{

printf("开始查询学生信息: ");


while(1)

{

printf("通过什么查询?1:学生id 2:学生名字 3:学生语文成绩 4:学生数学成绩 5:学生英语成绩 6:学生计算机成绩 7:平均分 -1 退出 ");

int squery,squery2;

scanf("%d", &squery);

if(squery==-1)break;

Student temp;

Student* newStudent = &temp;

if(squery==1)

{

printf("请输入学生id: ");

scanf("%lld", &(newStudent->id));

}

else if(squery==2)

{

printf("请输入学生名字: ");

scanf("%10s", newStudent->name);

scanf("%*[^ ]");

}

else if(squery==3)

{

printf("请输入学生语文成绩: ");

scanf("%d",&(newStudent->score[0]));

}

else if(squery==4)

{


printf("请输入学生数学成绩: ");

scanf("%d",&(newStudent->score[1]));

}

else if(squery==5)

{

printf("请输入学生英语成绩: ");

scanf("%d",&(newStudent->score[2]));

}

else if(squery==6)

{

printf("请输入学生计算机成绩: ");

scanf("%d",&(newStudent->score[3]));

}

else if(squery==7)

{

printf("请输入学生平均分: ");

scanf("%lf",&(newStudent->avg));

}

if(squery>=3 && squery<=7)

{

printf("显示比此分数高还是低的学生?1:低 2:高 ");

scanf("%d",&squery2);

}


Student* stu = head;

int flag=0;

while(stu!=0)

{

if(squery==1)

{

if(newStudent->id==stu->id)

{

print(stu);

flag=1;

}

}

else if(squery==2)

{

if(strcmp(newStudent->name,stu->name)==0)

{

print(stu);

flag=1;

}

}

else if(squery==7)

{

if((newStudent->avg!=stu->avg) && ((newStudent->avg>stu->avg) ^ (squery2==2)))

{

print(stu);

flag=1;

}

}

else if(squery>2 && squery<7)

{

if((newStudent->score[squery-3]!=stu->score[squery-3]) && ((newStudent->score[squery-3]>stu->score[squery-3]) ^ (squery2==2)))

{

print(stu);

flag=1;

}

}


stu=stu->next;

}

if(flag==0)

{

printf("没有查到学生! ");

continue;

}



}

}

else if(quest==4)

{

printf("开始修改学生信息: ");


while(1)

{

printf("请输入学生学号(-1退出修改): ");

long long int id;

scanf("%lld", &id);


if(id==-1)break;


Student* newStudent = head;

Student* lststu = 0;

while(newStudent!=0 && newStudent->id!=id)

{

lststu=newStudent;

newStudent=newStudent->next;

}

if(newStudent==0)

{

printf("没有查到学生! ");

continue;

}

printf("请输入操作号:1:修改学生名字 2:修改学生语文成绩 3:修改学生数学成绩 4:修改学生英语成绩 5:修改学生计算机成绩 6:删除学生 ");


int squery;

scanf("%d", &squery);

if(squery==1)

{

printf("请输入学生名字: ");

scanf("%10s", newStudent->name);

scanf("%*[^ ]");

}

else if(squery==2)

{


printf("请输入学生语文成绩: ");

scanf("%d",&(newStudent->score[0]));

}

else if(squery==3)

{


printf("请输入学生数学成绩: ");

scanf("%d",&(newStudent->score[1]));

}

else if(squery==4)

{

printf("请输入学生英语成绩: ");

scanf("%d",&(newStudent->score[2]));

}

else if(squery==5)

{

printf("请输入学生计算机成绩: ");

scanf("%d",&(newStudent->score[3]));

}

else if(squery==6)

{

stucount--;

if(lststu!=0)

lststu -> next = newStudent -> next;

else

head = newStudent -> next;

printf("已删除学生! ");

}

if(squery!=6)

{

int sum=0;

for(int i=0; i<4; ++i)sum+=newStudent->score[i];

newStudent->avg = sum/4.0;

printf("学生已修改!他的平均分为:%lf ",newStudent->avg);

}

}

}

else if(quest==5)

{

if(head==0)

printf("没有学生! ");

else

{

printf("对学生按什么排序?:1:学生号 2:名字 3:语文成绩 4:数学成绩 5:修改学生英语成绩 5:计算机成绩 6:平均分 ");

int squery;

scanf("%d", &squery);

printf("升序还是降序? 1:升序 2:降序 ");

int squery2;

scanf("%d", &squery2);

int flag=1;

Student* stu = head;

Student* lststu = 0;

while(flag==1)

{

flag=0;

while(stu->next!=0)

{

int swflag=0;

if(squery==0)

{

if((stu->next->id > stu->id) ^ (squery2==1))swflag=1;

}

else if(squery==1)

{

if((strcmp(stu->next->name,stu->name)>0) ^ (squery2==1))swflag=1;

}

else if(squery==6)

{

if((stu->next->avg > stu->avg) ^ (squery2==1))swflag=1;

}

if(swflag==1)

{

flag=1;

if(lststu==0) head=stu->next;

else lststu->next=stu->next;

Student* temp = stu->next->next;

stu->next->next=stu;

stu->next=temp;

}

lststu=stu;

stu=stu->next;

}

}

printf("已排序! ");

}


}

else if(quest==6)

{


double totscore[4]= {0};

double sum=0;

Student* stu=head;

while(stu!=0)

{

for(int i=0; i<4; ++i)

{

totscore[i]+=stu->score[i];

sum+=stu->avg;

}

}

for(int i=0; i<4; ++i) totscore[i]=totscore[i]/4.0;

sum=sum/4.0;

printf("统计:学生人数:%d 语文平均分:%lf 数学平均分:%lf 英语平均分:%lf 计算机平均分:%lf 总平均分:%lf ",stucount,totscore[0],totscore[1],totscore[2],totscore[3],sum);

}

else if(quest==-1)

break;

}

return 0;

}

㈡ 设计一个学生管理系统,假设每个学生包括如下信息:学号,姓名,各门课成绩(数学,英语,C++)

首先你要有一个登录功能,登陆成功进入学生列表
列表显示全部学生信息,专也支持按学号或姓名属的模糊查询 ,并进行排序
每条列表后面有一个删除按钮和修改按钮
删除按钮直接根据id删除,修改按钮进入修改页面,

工具栏有添加学生信息功能 进入添加页面
修改删除,新增后都要生成 记录文件.dat,每次覆盖掉旧的dat,你不覆盖也可以
然后还有注销功能

㈢ 假设一个Excel工作表中包含某班所有学生的计算机成绩,如何计算出该班级计算机成绩

假如计算机成绩在a2到a80
你找个空格输入=sum(a2:a80),就是总成绩
求平均,再找个空格输入=sum(a2:a80)/79
79是人数

㈣ 假设score.txt文件中保存了三个班学生的考试成绩,请编写一段shell程序来计算每个班级的学生人数与平均分

只要文件中每行为一个学生的成绩列表 分数是分开的
是可以做到的。看score.txt的内容具体格式是什么了

㈤ 假设有3个学生 每个学生均选修了4门课程 计算出每个学生的平均分与总成绩 的c语言 编程怎么写

#include <stdio.h>
#define M 4
#define N 3
void main()
{
float score[M],add[N]={0},k[M]={0};
int i,j;
for(i=0;i<N;i++)
{
add[i]=0;
printf("输入第%d个学生%d门课专程的成绩属\n",i+1,M);
for(j=0;j<M;j++)
{
scanf("%f",&score[j]);
add[i]+=score[j];
k[j]+=score[j];
}
}
for(i=0;i<N;i++)
printf("第%d个学生平均成绩:%.1f\n",i+1,add[i]/M);
for(i=0;i<M;i++)
printf("第%d门课的平均成绩:%.1f\n",i+1,k[i]/N);
}

㈥ 设计一个学生成绩管理系统,假设每个学生包括如下信息:学号、姓名、各门课成绩(数学、英语、C语言)。

void print(struct student *);
void input(struct student *);

struct student
{
int num;
char name[20];
int score[3];
}stu[10];

struct student *p;

void main()
{
p = stu;
input(p);
print(p);
system("pause");
}

void input(struct student *p)
{
int i = 0, j;
for(p = stu; p < stu + 2; p++, i++)
{
("请输入第%d个人的学号:", i + 1);
scanf("%d",&p->num);
printf("请输入第%d个人的姓名:", i + 1);
scanf("%s",&p->name);
for(j = 0; j < 3; j++)
{
printf("请输入他第%d门课的成绩:", j + 1);
scanf("%d",&p->score[j]);
}
}
p = stu;
}

void print(struct student *p)
{
int num, j;
float avg, sum = 0;
struct student *q;
num = p->score[0];
for(q = p; q < p + 2; q++)
{
for(j = 0; j < 3; j++)
{
if(q->score[j] > num)
num = q->score[j];
sum += q->score[j];
}
}
avg = sum / 3 * 2;
printf("%f\t%d\n", avg, num); //找出最大的一个然后比较,找到最大的那个所在的哪一个stu[i],然后输出这个组的所有数据就搞定···
for(q = p; q < p + 2; q++)
{
for(j = 0; j < 3; j++)
if(q->score[j] == num)
{
printf("%d\t%s\n",q->num, q->name);
for(j = 0; j < 3; j++)
printf("%d\t",q->score[j]);
printf("\n");
break;
}
}
}

㈦ 假设某学校有一个学生成绩管理系统。其中用到一张表,表名为student(有学生学号、姓名、语文、数学、英语

如果不是专门为了练习编程,Excel表格就能完成你想得到的。

㈧ 假设数据库中有学生信息表、课程信息表和成绩表三个表查处所有信息及总分数怎么做

select b1.name,b2.name,b3.chengji from b1 inner join (b2 inner join b3 on b2.id=b3.b2ID) on b1.id=b2.b2ID where b2.name='数据库' and b3.chengji>69 and b1.zhuanye='计算机回答' order by b3.chengji desc

㈨ 假设ACCESS数据库中有一个学生成绩表,用SQL语令查询学生的学号和成绩

(1)select学号复,成绩制from学生成绩表where姓名='张三'
(2)select班级,count(*)人数from学生成绩表groupby班级
(3)selectmax(成绩)from学生成绩表

㈩ 假设有一个成绩表score,有id、学号stu_id、分数score三个字段,将此表跟上述学生表进

mysql 左连接
select * from tb_student(学生表版权) stu left join score sco on stu.id=sco.stu_id;
右连接
select * from tb_student(学生表) stu right join score sco on stu.id=sco.stu_id;

热点内容
武汉大学学生会辅导员寄语 发布:2021-03-16 21:44:16 浏览:612
七年级学生作文辅导学案 发布:2021-03-16 21:42:09 浏览:1
不屑弟高考成绩 发布:2021-03-16 21:40:59 浏览:754
大学毕业证会有成绩单 发布:2021-03-16 21:40:07 浏览:756
2017信阳学院辅导员招聘名单 发布:2021-03-16 21:40:02 浏览:800
查询重庆2018中考成绩查询 发布:2021-03-16 21:39:58 浏览:21
结业考试成绩怎么查询 发布:2021-03-16 21:28:40 浏览:679
14中医医师资格笔试考试成绩查分 发布:2021-03-16 21:28:39 浏览:655
名著赏析课程标准 发布:2021-03-16 21:27:57 浏览:881
北京大学商业领袖高端培训课程 发布:2021-03-16 21:27:41 浏览:919