鱼C论坛

 找回密码
 立即注册
查看: 861|回复: 1

动态结构体数组编程

[复制链接]
发表于 2021-12-8 22:04:00 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
动态结构体数组编程:定义一个结构体Student,成员有num,name和C,Java, Python三门课程的成绩以及平均分ave ,
定义一个动态结构体数组a,存储N个学生信息,从键盘输入N和N个学生数据,计算每个学生平均分,输出N个学生的所有信息。
输入:(1)N;(2)N个学生数据(num, name,C,Java,Python),数据用空格隔开。输出:输出N个学生的所有信息(num, name,C,Java, Python, ave),
数据用空格隔开,平均分保留小数点后1位。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-12-9 06:41:44 | 显示全部楼层
本帖最后由 jhq999 于 2021-12-9 07:03 编辑
typedef struct STUDENT
{
   int id;
   char name[16];
   int *achievement;
   float average;
   float sum;
}Student,pStudent;
int main(void) {
        


int i=0,j=0,M=0,N=0;//M学生数量,N科目数量
scanf("%d%d",&M,&N);
Student *a=new Student[M];
int *ptmp=new int[M*N];
for(i=0;i<M;i++)
{
   //a[i].id=i;
   scanf("%d",&a[i].id);
   scanf("%s",a[i].name);
   a[i].achievement=ptmp+i*N;
   a[i].sum=0;
   a[i].average=0;
   for(j=0;j<N;j++)
    {
        scanf("%d",&a[i].achievement[j]);
        a[i].sum+=a[i].achievement[j];
    }
    a[i].average=a[i].sum/N;
   // printf("%.1f  ",a[i].average);
}
//printf("\n");
/*Student stmp={0};
int flag=1;
for(i=0;i<M-1;i++)
{
   flag=1;
   for(j=1;j<M-i;j++)
   {
        if(a[j-1].sum<a[j].sum)
        {
              flag=0;
              stmp=a[j-1],a[j-1]=a[j],a[j]=stmp;
         }
    }
   if(flag)break;
}
i=0;
while(a[i].sum==a[0].sum&&i<N)
{
   printf("%d ",a[i].id+1);
   i++;
}
printf("\n");
for(i=0;i<M;i++)printf("%d ",a[i].id+1);*/
for(i=0;i<M;i++)
{
     printf("%d %s ",a[i].id,a[i].name);
     for(j=0;j<N;j++)printf("%d ",a[i].achievement[j]);
     printf("%.1f\n",a[i].average);
}

delete[] ptmp;
delete[] a;
        return 0;
}
4 3
1 abc 50 60 75
2 bcd 90 100 81
3 cde 40 80 99
4 def 88 90 53
1 abc 50 60 75 61.7
2 bcd 90 100 81 90.3
3 cde 40 80 99 73.0
4 def 88 90 53 77.0
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-9-23 07:29

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表