| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 461 人关注过本帖
标题:【求助】一个简单的小型学生管理程序,但其中有个功能不知如何实现
只看楼主 加入收藏
mandown1991
Rank: 4
等 级:业余侠客
帖 子:262
专家分:252
注 册:2011-3-2
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:3 
【求助】一个简单的小型学生管理程序,但其中有个功能不知如何实现
求助论坛里的各位前辈,这是我们老师出的一道题目,下面是我已经编出来的程序,但是第五个功能中“当成绩相等时再按照学号升序排列”不知如何实现,所以在此请教一下!感激不尽!
原题目:
每个学生的记录为:学号,姓名,性别,英语,数学,程序设计。(对此设计结构体)
编程实现以下功能:
(1)输入每位学生的各项信息(至少5位)。
(2)计算每位学生的总分和平均分。
(3)计算每门课程的平均分及最高、最低分。
(4)查找所有重修学生的学号、姓名和重修科目。
(5)对所有记录按照平均成绩降序排列,当成绩相等时再按照学号升序排列。
要求:使用到结构体和指针
程序代码:
#include<stdio.h>
#include<conio.h>
#define N 5        //学生人数

struct student
{
    int num[10];
    char name[20];
    char sex[10];
    float Escore;
    float Mscore;
    float Cscore;
}stud[N];

int i;    //全局变量

void GetInfo()    //(1)输入每位学生的各项信息(至少5位)
{
    printf("请输入每位学生的信息:\n");
    for(i=0;i<N;i++)
    {
        printf("\n第%d位学生的信息\n",i+1);
        printf("学号:");
        scanf("%d",stud[i].num);
        printf("姓名:");
        scanf("%s",stud[i].name);
        printf("性别:");
        scanf("%s",stud[i].sex);
        printf("英语成绩:");
        scanf("%f",&stud[i].Escore);
        printf("数学成绩:");
        scanf("%f",&stud[i].Mscore); 
        printf("程序设计成绩:");
        scanf("%f",&stud[i].Cscore);
    }
}

void TotalAndAverage()    //(2)计算每位学生的总分和平均分
{
    printf("\n姓名\t\t总分\t\t\t平均分\n");
    for(i=0;i<N;i++)
        printf("%s\t\t%f\t\t%f\n",stud[i].name,stud[i].Escore+stud[i].Mscore+stud[i].Cscore,(stud[i].Escore+stud[i].Mscore+stud[i].Cscore)/3);
}

void EachCourse()    //(3)计算每门课程的平均分及最高、最低分
{
    void HighestAndLowest();
    float English=0,Math=0,CProgramming=0;
    for(i=0;i<N;i++)
    {
        English=English+stud[i].Escore;
        Math=Math+stud[i].Mscore;
        CProgramming=CProgramming+stud[i].Cscore;
    }
    printf("\n英语平均分\t数学平均分\t程序设计平均分\n%f\t%f\t%f\n",English/N,Math/N,CProgramming/N);
    HighestAndLowest();
}

void HighestAndLowest()    //每门课程的最高、最低分
{
    float *H_E,*H_M,*H_C,*L_E,*L_M,*L_C;
    H_E=&stud[0].Escore,H_M=&stud[0].Mscore,H_C=&stud[0].Cscore;
    L_E=H_E,L_M=H_M,L_C=H_C;
    for(i=0;i<N-1;i++)
    {
        if(*H_E<stud[i+1].Escore)
            H_E=&stud[i+1].Escore;
        if(*H_M<stud[i+1].Mscore)
            H_M=&stud[i+1].Mscore;
        if(*H_C<stud[i+1].Cscore)
            H_C=&stud[i+1].Cscore;
        if(*L_E>stud[i+1].Escore)
            L_E=&stud[i+1].Escore;
        if(*L_M>stud[i+1].Mscore)
            L_M=&stud[i+1].Mscore;
        if(*L_C>stud[i+1].Cscore)
            L_C=&stud[i+1].Cscore;
    }
    printf("\n英语最高分\t数学最高分\t程序设计最高分\n%f\t%f\t%f\n",*H_E,*H_M,*H_C);
    printf("\n英语最低分\t数学最低分\t程序设计最低分\n%f\t%f\t%f\n",*L_E,*L_M,*L_C);
}

void Search()    //(4)查找所有重修学生的学号、姓名和重修科目
{

    printf("\n学号\t\t姓名\t\t重修科目\n");
    for(i=0;i<N;i++)
    {
        if(stud[i].Escore<60||stud[i].Mscore<60||stud[i].Cscore<60)
        {
            printf("%d\t\t%s\t\t",*stud[i].num,stud[i].name);
            if(stud[i].Escore<60)
                printf("英语 ");
            if(stud[i].Mscore<60)
                printf("数学 ");
            if(stud[i].Cscore<60)
                printf("程序设计 ");
            printf("\n");
        }
    }
}

void Rank()        //(5)对所有记录按照平均成绩降序排列,当成绩相等时再按照学号升序排列
{
    float average[N],temp_1=0,*pa;       
    int j,temp_2=0,*pn;
    pa=&average[0],pn=stud[0].num;

    printf("\n所有记录(未排序)\n");
    printf("\n学号\t\t平均分\n");
    for(i=0;i<N;i++)
    {
        average[i]=(stud[i].Escore+stud[i].Mscore+stud[i].Cscore)/3;
        printf("%d\t\t%f\n",*stud[i].num,average[i]);
    }

    printf("\n所有记录(已排序)\n");
    printf("\n学号\t\t平均分\n");
    for(i=0;i<N-1;i++)
    {
        if(average[i]==average[i+1])
        {
            for(i=0;i<N;i++)
            {
                for(j=0;j<N-i-1;j++)
                {   
                    if(*(pn+j)>*(pn+j+1))
                    {
                        temp_2=*(pn+j+1);
                        *(pn+j+1)=*(pn+j);
                        *(pn+j)=temp_2;
                    }
                }
            }
            pn++;
            printf("%d\t\t%f\n",*pn,average[i]);
        }
        else
        {
            for(i=0;i<N;i++)
            {
                for(j=0;j<N-i-1;j++)
                {   
                    if(*(pa+j)<*(pa+j+1))
                    {
                        temp_1=*(pa+j+1);
                        *(pa+j+1)=*(pa+j);
                        *(pa+j)=temp_1;
                    }
                }
            }
            pa++;
            printf("%d\t\t%f\n",*stud[i].num,*pa);
        }
    }
}    

int main(void)
{
    GetInfo();
    TotalAndAverage();
    EachCourse();
    Search();
    Rank();
    printf("\n按任意键结束本程序······\n");
    getch();
    return 0;
}
搜索更多相关主题的帖子: 如何 记录 结构体 老师 
2011-09-14 13:06
beyondyf
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:103
帖 子:3282
专家分:12654
注 册:2008-1-21
收藏
得分:20 
num字段没必要用数组,你的代码中对它也不是当数组用的。改成int型变量就好。

下面的函数可以实现你要求的排序

int cmp(const void * a, const void * b)
{
    struct student * pa, * pb;
    float suma, sumb;
    pa = (struct student *)a;
    pb = (struct student *)b;
    suma = pa->Escore + pa->Mscore + pa->Cscore;
    sumb = pb->Escore + pb->Mscore + pb->Cscore;
    if(suma > sumb) return -1;
    else if(suma < sumb) return 1;
    else return pa->num - pb->num;
}

qsort(stud, N, sizeof(struct student), cmp);

重剑无锋,大巧不工
2011-09-14 13:29
mandown1991
Rank: 4
等 级:业余侠客
帖 子:262
专家分:252
注 册:2011-3-2
收藏
得分:0 
回复 2楼 beyondyf
嗯嗯···谢谢!请问你是指结构体里面的num吗?然后你写的函数我还不能理解···不过先谢谢啊!
2011-09-14 17:38
mandown1991
Rank: 4
等 级:业余侠客
帖 子:262
专家分:252
注 册:2011-3-2
收藏
得分:0 
没有人吗??
2011-09-15 13:27
快速回复:【求助】一个简单的小型学生管理程序,但其中有个功能不知如何实现
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.015273 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved