第九次实验任务

任务1:
某班有最多不超过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);
	}
}


运行结果截图:



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值