假设有张学生成绩表
㈠ 假设收集到了一个班学生的所有成绩信息(不低于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;