任务1:
某班有最多不超过30人(具体人数由键盘输入)参加某门课程的考试,用一维数组作函数参数编程实现如下学生成绩管理:
(1) 录入每个学生的学号和考试成绩;
(2) 计算课程的总分和平均分;
(3) 按成绩由高到低排出名次表;
(4) 按学号由小到大排出成绩表;
(5) 按学号查询学生排名及其考试成绩;
(6) 按优秀(90~100)、良好(70~89)、及格(60~69)、不及格(0~59)5个类别,统计每个类别的人数及其所占的百分比;
(7) 输出每个学生的学号、考试成绩,课程总分和平均分。
代码如下:
#include<stdio.h>
#define max 30
void px(int *c,int *h,int n)
{
int t1,t2;
for(int i=0;i<n;i++)
{
for(int j=0;j<n-i-1;j++)
if(*(h+j)<*(h+j+1))
{
t1=*(h+j);
*(h+j)=*(h+j+1);
*(h+j+1)=t1;
t2=*(c+j);
*(c+j)=*(c+j+1);
*(c+j+1)=t2;
}
}
}
void main()
{
printf("这是个让人很不爽的学生成绩管理系统\n");
int number[max],score[max],shul,sum=0;
int i;
float ave;
printf("请输入学生的人数:\n");
scanf("%d",&shul);
printf("请输入学生的学号与分数:\n");
for(i=0;i<shul;i++)
{
scanf("%d,%d",&number[i],&score[i]);
}
for(i=0;i<shul;i++)
{
sum=sum+score[i];
}
printf("总分为:%d\n",sum);
ave=float(sum/shul);
printf("平均分为:%f\n",ave);
printf("成绩名次表:\n");
int *c,*h;
c=number;
h=score;
px(c,h,shul);
for(i=0;i<shul;i++)
{
printf("%d,%d\n",number[i],score[i]);
}
printf("由学号排出成绩:\n");
int t1,t2;
for(i=0;i<shul;i++)
{
for(int j=0;j<shul-i-1;j++)
{
if(number[j]>number[j+1])
{
t1=score[j];
score[j]=score[j+1];
score[j+1]=t1;
t2=number[j];
number[j]=number[j+1];
number[j+1]=t2;
}
}
}
for(i=0;i<shul;i++)
{
printf("%d,%d\n",number[i],score[i]);
}
printf("请输入您想要查询的学生学号:\n");
int a;
scanf("%d",&a);
for(i=0;i<shul;i++)
{
if(number[i]==a)
printf("学号:%d,名次:%d,成绩:%d\n",number[i],i+1,score[i]);
}
float m=0,n=0,q=0,z=0;
for(i=0;i<shul;i++)
{
if(score[i]>=90)
m++;
if(score[i]<90&&score[i]>=70)
q++;
if(score[i]<70&&score[i]>=60)
z++;
if(score[i]<60)
n++;
}
printf("优秀\t良好\t及格\t不及格\n");
printf("%f\t%f\t%f\t%f\n",m,q,z,n);
printf("%f%%\t%f%%\t%f%%\t%f%%\n",(m/shul)*100,(q/shul)*100,(z/shul)*100,(n/shul)*100);
getchar();
}
----------------------分割线----------------------
任务2:
从键盘输入5个整数存入一维数组中,输出最大的数,再按反序输出(要求用指针访问数组元素)
代码如下:
#include <stdio.h>
int main()
{
int a[5],m=0;
printf("请输入一个5位整数的数组:\n");
for(int i=0;i<5;i++)
{
scanf("%d",&a[i]);
}
int *p1=a;
int *p2=a+4;
for(;p1<p2;p1++,p2--)
{
int t;
t=*p1;
*p1=*p2;
*p2=t;
}
for(i=0;i<5;i++)
{
printf("%d ",a[i]);
}
for(i=0;i<5;i++)
{
if(m<a[i])
m=a[i];
}
printf("max=%d",m);
return 0;
}