天天看点

第十一周课后练习题(一)

实现一个成绩管理程序:

PPT里面说给学号、姓名占用的内存要求动态分配,既然如此不如直接给所有的结构体都动态分配

当然在看之前希望你们先看下我上一篇的代码不然typedef不太好理解,当然也可以不用typedef,毕竟这只是简化输出

#include<stdio.h>
#include<stdlib.h>

 typedef struct student
{
    char name[10]; 
    char xuehao[10];
    double yuwen;
    double math;
    double english;
    double sum;
    double average;
    
    
}cj;
int n;
double y_average,m_average,e_average;

void s_average(cj s[]);
void sum(cj s[]);
void meike_average(cj s[]);
void paixu(cj s[]);
void paixu(cj s[]);
int main()
{
    cj *s=(cj *)malloc(sizeof(cj)*10);
    int i,j;
    printf("请输入学生人数:");
    scanf("%d",&n);
    for(i=0;i<n;i++)
    {
        printf("请输入%d个学生的信息---姓名---学号---语文成绩---数学成绩---英语成绩\n",i+1);
        scanf("%s%s%lf%lf%lf",&s[i].name,&s[i].xuehao,&s[i].yuwen,&s[i].math,&s[i].english);
        
    } 
    sum(s);
    s_average(s);
    meike_average(s);
    puts("");
    for(i=0;i<n;i++)
    {
        printf("学生%s的总分为%.f\t各科平均分为%.2f\n",s[i].name,s[i].sum,s[i].average);
    }
        printf("\n");
        printf("各科平均分\n");
        printf("  \t平均分\n语 文\t  %.2f\n数 学\t  %.2f\n英 语\t  %.2f\n",y_average,m_average,e_average);
        
    paixu(s);
    puts("");
    printf("姓名\t学号\t语文\t英语\t数学\t总分\t平均分\t名次\n");
    for(i=0;i<n;i++)
    {
        
        printf("%s\t%s\t%.f\t%.f\t%.f\t%.f\t%.f\t%d\n",s[i].name,s[i].xuehao,s[i].yuwen,s[i].english,s[i].math,s[i].sum,s[i].average,i+1);
    }
    free(s);
    s = NULL;
}

void sum(cj s[])
{
    int i;
    
    for(i=0;i<n;i++)
    {
        s[i].sum=s[i].math+s[i].english+s[i].yuwen;
    }
}

void s_average(cj s[])
{
    int i;
    
    for(i=0;i<n;i++)
    {
        s[i].average=(s[i].math+s[i].english+s[i].yuwen)/3;
    }
     
}

void meike_average(cj s[]) 
{
    int i;
    double sum1=0,sum2=0,sum3=0;
    for(i=0;i<n;i++)
    {
            sum1+=s[i].yuwen;
            sum2+=s[i].math;
            sum3+=s[i].english;
    } 
    y_average=sum1/n;
    m_average=sum2/n;
    e_average=sum3/n;
}


void paixu(cj s[])
{
    int i,j,t,flag;
    struct student temp;
    for (i = 0; i < n-1; i++)       //轮次,共NUM-1次
    {
       flag = 0;
       for (j = 0; j < n - i-1; j++)  //实现一次冒泡操作
           if (s[j].sum < s[j+1].sum)                  //交换a[j]和a[j+1]
           {   temp = s[j];   s[j] = s[j+1];  s[j+1] = temp;  
                
                   flag = 1;  
            }
       if (flag == 0)  break;
    }
}      
1.C
 2.D
 3.A
 4.A
 5.D
 6.C
 7.A
 8.D
 9.A
 10.C
 11.D
 12.A
 13.C
 14.C
 15.D 00001000 00000000
 11000101 11110000
 16.A
 17.A
 18.A
 19.C
 20.A