pta第四次作业
1 实验设计思路
本题中要我们边写一段形参,来挑出ABCD等级的人,对此我们可以循环使用if函数,来把学生的成绩和等级成绩进行比较,根据判断结果,我们来给grade进行赋值操作。
2 流程图
3实验代码
#include <stdio.h>
#define MAXN 10
struct student{
int num;
char name[20];
int score;
char grade;
};
int set_grade( struct student *p, int n );
int main()
{ struct student stu[MAXN], *ptr;
int n, i, count;
ptr = stu;
scanf("%d\n", &n);
for(i = 0; i < n; i++){
scanf("%d%s%d", &stu[i].num, stu[i].name, &stu[i].score);
}
count = set_grade(ptr, n);
printf("The count for failed (<60): %d\n", count);
printf("The grades:\n");
for(i = 0; i < n; i++)
printf("%d %s %c\n", stu[i].num, stu[i].name, stu[i].grade);
return 0;
}
int set_grade( struct student *p, int n )
{ int x=0;
int i;
{for(i=0;i<n;i++,p++)
if(p->score>=85&&p->score<=100)
p->grade='A';
else if(p->score<85&&p->score>=70)
p->grade='B';
else if(p->score<70&&p->score>=60)
p->grade='C';
else if(p->score<60&&p->score>=0)
{p->grade='D';
x++;}
}
return x;
}
4 本题遇到的问题
忘记返回x的值
在结尾加上return x;
5 git地址 https://git.coding.net/hxc980203/123.git
4.2
1 实验设计思路:
本题目中要我们对于结构体中的学生的成绩进行求和,并且根据总成绩的大小对学生进行排序
首先我们可以先用for循环求每一个学生的总成绩并将总成绩赋值给sum变量
然后我们再用冒泡排序法对学生进行排序。
2 流程图
无
3实验代码
#include <stdio.h>
struct student
{
int num;
char name[15];
float score[3];
float sum;
};
void calc(struct student *p,int n);
void sort(struct student *p,int n);
int main()
{
struct student stu[5];
int i,j;
float f;
for(i=0;i<5;i++)
{
scanf("%d%s",&stu[i].num,stu[i].name);
for(j=0;j<3;j++)
{
scanf("%f",&f);
stu[i].score[j]=f;
}
}
calc(stu,5);
sort(stu,5);
for(i=0;i<5;i++)
{
printf("%5d%15s",stu[i].num,stu[i].name);
printf(" %.1f %.1f %.1f %.1f\n",stu[i].score[0],stu[i].score[1],stu[i].score[2], stu[i].sum);
}
return 0;
void calc(struct student *p,int n)
{ int i;
for(i=0;i<n;i++,p++)
{
p->sum=p->score[0]+p->score[1]+p->score[2];
}
}
void sort(struct student *p,int n)
{ struct student t;
int i,j;
for(j=0;j<n-1;j++)
for(i=0;i<n-1-j;i++)
if((p+i)->sum<(p+i+1)->sum)
{t=*(p+i);
*(p+i)=*(p+1+i);
*(p+1+i)=t;
}
}
4 本题中遇到的问题
对于冒泡排序法还是不够熟练
5 git地址 https://git.coding.net/hxc980203/566.git