任务1:
某班有最多不超过30人(具体人数由键盘输入)参加某门课程的考试,用一维数组作函数参数编程实现如下学生成绩管理:
(1)录入每个学生的学号和考试成绩;
(2)计算课程的总分和平均分;
(3)按成绩由高到低排出名次表;
(4)按学号由小到大排出成绩表;
(5)按学号查询学生排名及其考试成绩;
(6)按优秀(90~100)、良好(70~89)、及格(60~69)、不及格(0~59)5个类别,统计每个类别的人数及其所占的百分比;
任务2:
某班有最多不超过30人(具体人数由键盘输入)参加某门课程的考试,用一维数组作函数参数编程实现如下学生成绩管理:
(1)录入每个学生的学号和考试成绩;
(2)计算课程的总分和平均分;
(3)按成绩由高到低排出名次表;
(4)按学号由小到大排出成绩表;
(5)按学号查询学生排名及其考试成绩;
(6)按优秀(90~100)、良好(70~89)、及格(60~69)、不及格(0~59)5个类别,统计每个类别的人数及其所占的百分比;
(7)输出每个学生的学号、考试成绩,课程总分和平均分。
我的程序:
#include<stdio.h>
#define N 30
void main()
{
int xh[N],cj[N],rs,sum=0,i;
float ave;
printf("这是一个学生成绩管理系统!\n");
printf("请输入学生的数量:");
scanf_s("%d",&rs);
if(rs<=N)
{
printf("请输入学生的学号和考试成绩:\n");
for(i=0;i<rs;i++)
{
scanf_s("%d,%d",&xh[i],&cj[i]);
}
for(i=0;i<rs;i++)
{
sum=sum+cj[i];
}
ave= float(sum/rs);
printf("总分为:%d\n",sum);
printf("平均分为:%f\n",ave);
printf("按照学号排序:\n");
int t3,t4;
for(i=0;i<rs;i++)
for(int j=0;j<rs-i-1;j++)
{
if(xh[j]>xh[j+1])
{
t3=cj[j];
cj[j]=cj[j+1];
cj[j+1]=t3;
t4=xh[j];
xh[j]=xh[j+1];
xh[j+1]=t4;
}
}
for(i=0;i<rs;i++)
{
printf("%d,%d\n",xh[i],cj[i]);
}
int t5,t6;
for(i=0;i<rs;i++)
for(int j=0;j<rs-i-1;j++)
{
if(cj[j]<cj[j+1])
{
t5=cj[j];
cj[j]=cj[j+1];
cj[j+1]=t5;
t6=xh[j];
xh[j]=xh[j+1];
xh[j+1]=t6;
}
}
printf("按成绩排序:\n");
for(i=0;i<rs;i++)
printf("%d,%d\n",xh[i],cj[i]);
int x;
printf("请输入你想要查的学生的学号:\n");
scanf_s("%d",&x);
for(i=0;i<rs;i++)
{
if(x==xh[i])
printf("学号:%d,名次:%d,考试成绩:%d\n",xh[i],(i+1),cj[i]);
}
int t=0,s=0,l=0,r=0;
for(i=0;i<rs;i++)
{
if(cj[i]>=90&&cj[i]<=100)
t++;
if(cj[i]>=70&&cj[i]<=89)
s++;
if(cj[i]>=60&&cj[i]<=69)
l++;
if(cj[i]<=59)
r++;
}
printf("优秀\t良好\t及格\t不及格\n");
printf("%d\t%d\t%d\t%d\n",t,s,l,r);
printf("%.f%%\t%.f%%\t%.f%%\t%.f%%\n",(t*1.0/rs*100),(s*1.0/rs*100),(l*1.0/rs*100),(r*1.0/rs*100));
}
}
运行结果截图:我表示我的电脑一直截不到最后的那个,到最后总是一闪,然后没了
----------------------分割线----------------------任务2:
从键盘输入5个整数存入一维数组中,输出最大的数,再按反序输出(要求用指针访问数组元素)
我的程序:
#include<stdio.h>
#define N 5
void main()
{
int i,sz[N],max=0;
int *p;
printf("请输入五个数:\n");
for(i=0;i<N;i++)
{
scanf_s("%d",&sz[i]);
}
for(i=0;i<N;i++)
{
if(sz[i]>max)
max=sz[i];
}
printf("这五个数中的最大数为:%d\n",max);
printf("这五个数的反序:");
for(p=sz+N-1;p>sz-1;p--)
{
printf("%2d",*p);
}
}
运行结果截图: