| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 896 人关注过本帖
标题:这里有个很难的题目,请指教!!
只看楼主 加入收藏
哎呀东东
Rank: 1
等 级:新手上路
帖 子:10
专家分:1
注 册:2011-6-7
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:12 
这里有个很难的题目,请指教!!
学校要做个C语言 学生成绩管理系统..要有成绩录入,修改,显示以及保存,还有能够显示成绩平均分及各科最高分...谢谢了,我不会做完整...


    功能设计要求:
1)本系统采用两个结构体数组进行数据存储。学生结构体应该包括学生的基本信息(学号、姓名、所选课程),课程结构包括各项课程的基本信息(所选的各门课程对应的成绩)
2)设计主菜单界面,确定函数个数。设计菜单应包含以下功能:
录入信息(学生基本信息录入、课程成绩基本信息录入)
显示(显示学生基本情况和所选课程成绩)
修改信息(学生基本信息修改、成绩基本信息修改)
成绩统计(各科成绩最高分,平均分)
退出系统
    3)要求:建立两个结构体数组(或链表、文件),包括至少3门课程成绩和5个学生的必要信息,能对数据进行补充、修改。执行一个具体的功能之后,程序将重新显示菜单。
丫的,这是坑爹啊!!

/***********xuesheng.c***********/
/******头文件(.h)***********/
#include "stdio.h"    /*I/O函数*/
#include "stdlib.h"   /*其它说明*/
#include "string.h"   /*字符串函数*/
#include "conio.h"   /*屏幕操作函数*/
#include "mem.h"   /*内存操作函数*/
#include "ctype.h"   /*字符操作函数*/
#include "alloc.h"   /*动态地址分配函数*/
#define N 3       /*定义常数*/
typedef struct z1   /*定义数据结构*/
{
   char no[11];
   char name[15];
   int score[N];
   float sum;
   float average;
   int order;
   struct z1 *next;
 }STUDENT;
/*以下是函数原型*/
STUDENT  *init();      /*初始化函数*/
STUDENT *create();   /*创建链表*/
STUDENT *delete(STUDENT *h);   /*删除记录*/
void print(STUDENT *h);   /* 显示所有记录*/
void search(STUDENT *h);    /*查找*/
void save(STUDENT *h);     /*保存*/
STUDENT *load();        /*读入记录*/
void computer(STUDENT *h);  /*计算总分和均分*/
STUDENT *insert(STUDENT *h);   /*插入记录*/
void append();            /*追加记录*/
void copy();            /*复制文件*/
STUDENT *sort(STUDENT *h);    /*排序*/
STUDENT *index(STUDENT *h);  /*索引*/
void total(STUDENT *h);       /*分类合计*/
int menu_select();            /*菜单函数*/
/******主函数开始*******/
main()
{
   int i;
   STUDENT *head;     /*链表定义头指针*/
   head=init();          /*初始化链表*/
   clrscr();            /*清屏*/
   for(;;)             /*无限循环*/
   {
      switch(menu_select())     /*调用主菜单函数,返回值整数作开关语句的条件*/
      {                     /*值不同,执行的函数不同,break 不能省略*/
     case 0:head=init();break;   /*执行初始化*/
     case 1:head=create();break; /*创建链表*/
     case 2:head=delete(head);break; /*删除记录*/
     case 3:print(head);break;   /*显示全部记录*/
     case 4:search(head);break;  /*查找记录*/
     case 5:save(head);break;  /*保存文件*/
     case 6:head=load(); break;  /*读文件*/
     case 7:computer(head);break;  /*计算总分和均分*/
     case 8:head=insert(head);  break; /*插入记录*/
     case 9:copy();break;    /*复制文件*/
     case 10:head=sort(head);break;  /*排序*/
     case 11:append();break;     /*追加记录*/
     case 12:head=index(head);break;  /*索引*/
     case 13:total(head);break;   /*分类合计*/
     case 14:exit(0);       /*如菜单返回值为14程序结束*/
      }
   }
}
/*菜单函数,返回值为整数*/
menu_select()
{
   char *menu[]={"***************MENU***************",  /*定义菜单字符串数组*/
   " 0. init list",    /*初始化*/
   " 1. Enter list",   /*输入记录*/
   " 2. Delete a record from list",  /*从表中删除记录*/
   " 3. print list ",       /*显示单链表中所有记录*/
   " 4. Search record on name",   /*按照姓名查找记录*/
   " 5. Save the file",          /*将单链表中记录保存到文件中*/
   " 6. Load the file",        /*从文件中读入记录*/
   " 7. compute the score",    /*计算所有学生的总分和均分*/
   " 8. insert record to list ",   /*插入记录到表中*/
   " 9. copy the file to new file",   /*复制文件*/
   " 10. sort to make new file",   /*排序*/
   " 11. append  record to file",   /*追加记录到文件中*/
   " 12. index on nomber",       /*索引*/
   " 13. total on nomber",      /*分类合计*/
   " 14. Quit"};              /*退出*/
   char s[3];       /*以字符形式保存选择号*/
   int c,i;        /*定义整形变量*/
   gotoxy(1,25);        /*移动光标*/
   printf("press any key enter menu......\n");   /*压任一键进入主菜单*/
   getch();                       /*输入任一键*/
   clrscr();                     /*清屏幕*/
   gotoxy(1,1);             /*移动光标*/
   textcolor(YELLOW);   /*设置文本显示颜色为黄色*/
   textbackground(BLUE);   /*设置背景颜色为蓝色*/
   gotoxy(10,2);          /*移动光标*/
   putch(0xc9);        /*输出左上角边框┏*/
   for(i=1;i<44;i++)
      putch(0xcd);    /*输出上边框水平线*/
   putch(0xbb);            /*输出右上角边框  ┓*/
   for(i=3;i<20;i++)
   {
      gotoxy(10,i);putch(0xba);   /*输出左垂直线*/
      gotoxy(54,i);putch(0xba);
   }   /*输出右垂直线*/
   gotoxy(10,20);putch(0xc8);  /*输出左上角边框┗*/
   for(i=1;i<44;i++)
      putch(0xcd);      /*输出下边框水平线*/
   putch(0xbc);                 /*输出右下角边框┛*/
   window(11,3,53,19);       /* 制作显示菜单的窗口,大小根据菜单条数设计*/
   clrscr();              /*清屏*/
   for(i=0;i<16;i++)       /*输出主菜单数组*/
   {
      gotoxy(10,i+1);
      cprintf("%s",menu[i]);
   }
   textbackground(BLACK);   /*设置背景颜色为黑色*/
   window(1,1,80,25);       /*恢复原窗口大小*/
   gotoxy(10,21);       /*移动光标*/
   do{
      printf("\n     Enter you choice(0~14):");    /*在菜单窗口外显示提示信息*/
      scanf("%s",s);           /*输入选择项*/
      c=atoi(s);            /*将输入的字符串转化为整形数*/
   }while(c<0||c>14);    /*选择项不在0~14之间重输*/
   return c;              /*返回选择项,主程序根据该数调用相应的函数*/
}
STUDENT *init()
{
   return NULL;
}

/*创建链表*/
STUDENT *create()
{
   int i; int s;
   STUDENT *h=NULL,*info;  /* STUDENT指向结构体的指针*/
   for(;;)
   {
      info=(STUDENT *)malloc(sizeof(STUDENT));  /*申请空间*/
      if(!info)   /*如果指针info为空*/
      {
     printf("\nout of memory");   /*输出内存溢出*/
     return NULL;           /*返回空指针*/
      }
      inputs("enter no:",info->no,11);   /*输入学号并校验*/
      if(info->no[0]=='@') break;    /*如果学号首字符为@则结束输入*/
      inputs("enter name:",info->name,15); /*输入姓名,并进行校验*/
      printf("please input %d score \n",N);  /*提示开始输入成绩*/
      s=0;         /*计算每个学生的总分,初值为0*/
      for(i=0;i<N;i++)    /*N门课程循环N次*/
      {
     do{
        printf("score%d:",i+1);    /*提示输入第几门课程*/
        scanf("%d",&info->score[i]);    /*输入成绩*/
        if(info->score[i]>100||info->score[i]<0) /*确保成绩在0~100之间*/
        printf("bad data,repeat input\n");  /*出错提示信息*/
     }while(info->score[i]>100||info->score[i]<0);
     s=s+info->score[i];   /*累加各门课程成绩*/
      }
      info->sum=s;    /*将总分保存*/
      info->average=(float)s/N;  /*求出平均值*/
      info->order=0;    /*未排序前此值为0*/
      info->next=h;   /*将头结点做为新输入结点的后继结点*/
      h=info;    /*新输入结点为新的头结点*/
   }
   return(h);   /*返回头指针*/
}
/*输入字符串,并进行长度验证*/
inputs(char *prompt, char *s, int count)
{
   char p[255];
   do{
      printf(prompt);  /*显示提示信息*/
      scanf("%s",p);  /*输入字符串*/
      if(strlen(p)>count)printf("\n too long! \n"); /*进行长度校验,超过count值重输入*/
   }while(strlen(p)>count);
   strcpy(s,p); /*将输入的字符串拷贝到字符串s中*/
}
/*输出链表中结点信息*/
void print(STUDENT *h)
{
   int i=0;     /* 统计记录条数*/
   STUDENT *p;  /*移动指针*/
   clrscr();     /*清屏*/
   p=h;      /*初值为头指针*/
   printf("\n\n\n****************************STUDENT********************************\n");
   printf("|rec|nO        |      name     | sc1| sc2| sc3|   sum  |  ave  |order|\n");
   printf("|---|----------|---------------|----|----|----|--------|-------|-----|\n");
   while(p!=NULL)
   {
       i++;
       printf("|%3d |%-10s|%-15s|%4d|%4d|%4d| %4.2f | %4.2f | %3d |\n", i, p->no,p->name,p->score[0],p->score[1],
p->score[2],p->sum,p->average,p->order);
       p=p->next;
   }
   printf("**********************************end*********************************\n");
}
/*删除记录*/
STUDENT *delete(STUDENT *h)
{
   STUDENT *p,*q;  /*p为查找到要删除的结点指针,q为其前驱指针*/
   char s[11];     /*存放学号*/
   clrscr();       /*清屏*/
   printf("please deleted no\n");      /*显示提示信息*/
   scanf("%s",s);   /*输入要删除记录的学号*/
   q=p=h;    /*给q和p赋初值头指针*/
   while(strcmp(p->no,s)&&p!=NULL)   /*当记录的学号不是要找的,或指针不为空时*/
   {
      q=p;       /*将p指针值赋给q作为p的前驱指针*/
      p=p->next;      /*将p指针指向下一条记录*/
   }
   if(p==NULL)     /*如果p为空,说明链表中没有该结点*/
      printf("\nlist no %s student\n",s);
   else       /*p不为空,显示找到的记录信息*/
   {
      printf("*****************************have found***************************\n");
      printf("|no        |      name     | sc1| sc2| sc3|   sum  |  ave  |order|\n");
      printf("|----------|---------------|----|----|----|--------|-------|-----|\n");
      printf("|%-10s|%-15s|%4d|%4d|%4d| %4.2f | %4.2f | %3d |\n", p->no,
       p->name,p->score[0],p->score[1],p->score[2],p->sum,
       p->average,p->order);
      printf("********************************end*******************************\n");
      getch();      /*压任一键后,开始删除*/
      if(p==h)    /*如果p==h,说明被删结点是头结点*/
     h=p->next;     /*修改头指针指向下一条记录*/
      else
     q->next=p->next; /*不是头指针,将p的后继结点作为q的后继结点*/
      free(p);          /*释放p所指结点空间*/
      printf("\n have deleted No %s student\n",s);
      printf("Don't forget save\n");/*提示删除后不要忘记保存文件*/
   }
   return(h);      /*返回头指针*/
}
/*查找记录*/
void search(STUDENT *h)
{
   STUDENT *p;    /*  移动指针*/
   char s[15];    /*存放姓名的字符数组*/
   clrscr();    /*清屏幕*/
   printf("please enter name for search\n");
   scanf("%s",s);    /*输入姓名*/
   p=h;    /*将头指针赋给p*/
   while(strcmp(p->name,s)&&p!=NULL)  /*当记录的姓名不是要找的,或指针不为空时*/
   p=p->next;     /*移动指针,指向下一结点*/
   if(p==NULL)         /*如果指针为空*/
      printf("\nlist no %s student\n",s);   /*显示没有该学生*/
   else           /*显示找到的记录信息*/
   {
      printf("\n\n*****************************havefound***************************\n");
      printf("|nO        |      name     | sc1| sc2| sc3|   sum  |  ave  |order|\n");
      printf("|----------|---------------|----|----|----|--------|-------|-----|\n");
      printf("|%-10s|%-15s|%4d|%4d|%4d| %4.2f | %4.2f | %3d |\n", p->no,
p->name,p->score[0],p->score[1],p->score[2],p->sum,p->average,p->order);
      printf("********************************end*******************************\n");
   }
}
/*插入记录*/
STUDENT  *insert(STUDENT *h)
{
   STUDENT *p,*q,*info; /*p指向插入位置,q是其前驱,info指新插入记录*/
   char s[11];  /*保存插入点位置的学号*/
   int s1,i;
   printf("please enter location  before the no\n");
   scanf("%s",s);   /*输入插入点学号*/
   printf("\nplease new record\n");      /*提示输入记录信息*/
   info=(STUDENT *)malloc(sizeof(STUDENT));   /*申请空间*/
   if(!info)
   {
      printf("\nout of memory");   /*如没有申请到,内存溢出*/
      return NULL;             /*返回空指针*/
   }
   inputs("enter no:",info->no,11); /*输入学号*/
   inputs("enter name:",info->name,15); /*输入姓名*/
   printf("please input %d score \n",N);  /*提示输入分数*/
   s1=0;    /*保存新记录的总分,初值为0*/
   for(i=0;i<N;i++)    /*N门课程循环N次输入成绩*/
   {
      do{        /*对数据进行验证,保证在0~100之间*/
     printf("score%d:",i+1);
     scanf("%d",&info->score[i]);
     if(info->score[i]>100||info->score[i]<0)
        printf("bad data,repeat input\n");
      }while(info->score[i]>100||info->score[i]<0);
      s1=s1+info->score[i];    /*计算总分*/
   }
   info->sum=s1;    /*将总分存入新记录中*/
   info->average=(float)s1/N;  /*计算均分*/
   info->order=0;         /*名次赋值0*/
   info->next=NULL;     /*设后继指针为空*/
   p=h;               /*将指针赋值给p*/
   q=h;             /*将指针赋值给q*/
   while(strcmp(p->no,s)&&p!=NULL)    /*查找插入位置*/
   {
      q=p;                 /*保存指针p,作为下一个p的前驱*/
      p=p->next;          /*将指针p后移*/
   }
   if(p==NULL)      /*如果p指针为空,说明没有指定结点*/
      if(p==h)      /*同时p等于h,说明链表为空*/
     h=info;   /*新记录则为头结点*/
      else
     q->next=info;  /*p为空,但p不等于h,将新结点插在表尾*/
   else
      if(p==h)     /*p不为空,则找到了指定结点*/
      {
     info->next=p; /*如果p等于h,则新结点插入在第一个结点之前*/
     h=info;    /*新结点为新的头结点*/
      }
      else
      {
     info->next=p;   /*不是头结点,则是中间某个位置,新结点的后继为p*/
     q->next=info;  /*新结点作为q的后继结点*/
      }
   printf("\n ----have inserted %s student----\n",info->name);    printf("---Don't forget save---\n");     /*提示存盘*/
   return(h);         /*返回头指针*/
}
/*保存数据到文件*/
void save(STUDENT *h)
{
   FILE *fp;         /*定义指向文件的指针*/
   STUDENT *p;    /* 定义移动指针*/
   char outfile[10];  /*保存输出文件名*/
   printf("Enter outfile name,for example c:\\f1\\te.txt:\n"); /*提示文件名格式信息*/
   scanf("%s",outfile);
   if((fp=fopen(outfile,"wb"))==NULL) /*为输出打开一个二进制文件,如没有则建立*/
   {
      printf("can not open file\n");
      exit(1);
   }
   printf("\nSaving file......\n");  /*打开文件,提示正在保存*/
   p=h;                    /*移动指针从头指针开始*/
   while(p!=NULL)        /*如p不为空*/
   {
      fwrite(p,sizeof(STUDENT),1,fp);/*写入一条记录*/
      p=p->next;        /*指针后移*/
   }
   fclose(fp);      /*关闭文件*/
   printf("-----save success!!-----\n");  /*显示保存成功*/
}
/* 从文件读数据*/
STUDENT *load()
{
   STUDENT *p,*q,*h=NULL;    /*定义记录指针变量*/
   FILE *fp;            /* 定义指向文件的指针*/
   char infile[10];       /*保存文件名*/
   printf("Enter infile name,for example c:\\f1\\te.txt:\n");   scanf("%s",infile);           /*输入文件名*/
   if((fp=fopen(infile,"rb"))==NULL)   /*打开一个二进制文件,为读方式*/
   {
      printf("can not open file\n");    /*如不能打开,则结束程序*/
      exit(1);
   }
   printf("\n -----Loading file!-----\n");
   p=(STUDENT *)malloc(sizeof(STUDENT));   /*申请空间*/
   if(!p)
   {
      printf("out of memory!\n");    /*如没有申请到,则内存溢出*/
      return h;       /*返回空头指针*/
   }
   h=p;         /*申请到空间,将其作为头指针*/
   while(!feof(fp))  /*循环读数据直到文件尾结束*/
   {
      if(1!=fread(p,sizeof(STUDENT),1,fp))
     break;  /*如果没读到数据,跳出循环*/
      p->next=(STUDENT *)malloc(sizeof(STUDENT));  /*为下一个结点申请空间*/
      if(!p->next)
      {
     printf("out of memory!\n");  /*如没有申请到,则内存溢出*/
     return h;
      }
      q=p;   /*保存当前结点的指针,作为下一结点的前驱*/
      p=p->next;   /*指针后移,新读入数据链到当前表尾*/
   }
   q->next=NULL;   /*最后一个结点的后继指针为空*/
   fclose(fp);       /*关闭文件*/
   printf("---You have success read data from file!!!---\n");
   return h;   /*返回头指针*/
}
/*追加记录到文件*/
void append()
{
   FILE *fp;      /*定义指向文件的指针*/
   STUDENT *info;    /*新记录指针*/
   int s1,i;
   char infile[10];    /*保存文件名*/
   printf("\nplease new record\n");
   info=(STUDENT *)malloc(sizeof(STUDENT));   /*申请空间*/
   if(!info)
   {
      printf("\nout of memory");   /*没有申请到,内存溢出本函数结束*/
      return ;
   }
   inputs("enter no:",info->no,11);    /*调用inputs输入学号*/
   inputs("enter name:",info->name,15); /*调用inputs输入姓名*/
   printf("please input %d score \n",N);   /*提示输入成绩*/
   s1=0;
   for(i=0;i<N;i++)
   {
      do{
     printf("score%d:",i+1);
     scanf("%d",&info->score[i]);  /*输入成绩*/
     if(info->score[i]>100||info->score[i]<0)printf("bad data,repeat input\n");
      }while(info->score[i]>100||info->score[i]<0); /*成绩数据验证*/
      s1=s1+info->score[i];      /*求总分*/
   }
   info->sum=s1;      /*保存总分*/
   info->average=(float)s1/N;  /*求均分*/
   info->order=0;      /*名次初始值为0*/
   info->next=NULL;  /*将新记录后继指针赋值为空*/
   printf("Enter infile name,for example c:\\f1\\te.txt:\n");    scanf("%s",infile);         /*输入文件名*/
   if((fp=fopen(infile,"ab"))==NULL)  /*向二进制文件尾增加数据方式打开文件*/
   {
      printf("can not open file\n");   /*显示不能打开*/
      exit(1);             /*退出程序*/
   }
   printf("\n -----Appending record!-----\n");
   if(1!=fwrite(info,sizeof(STUDENT),1,fp))   /*写文件操作*/
   {
      printf("-----file write error!-----\n");
      return;              /*返回*/
   }
   printf("-----append  sucess!!----\n");
   fclose(fp);       /*关闭文件*/
}
/*文件拷贝*/
void copy()
{
   char outfile[10],infile[10];
   FILE *sfp,*tfp;        /*源和目标文件指针*/
   STUDENT *p=NULL;   /*移动指针*/
   clrscr();    /*清屏*/
   printf("Enter infile name,for example c:\\f1\\te.txt:\n");
   scanf("%s",infile);         /*输入源文件名*/
   if((sfp=fopen(infile,"rb"))==NULL)   /*二进制读方式打开源文件*/
   {
      printf("can not open input file\n");
      exit(0);
   }
   printf("Enter outfile name,for example c:\\f1\\te.txt:\n");   /*提示输入目标文件名*/
   scanf("%s",outfile);  /*输入目标文件名*/
   if((tfp=fopen(outfile,"wb"))==NULL)  /*二进制写方式打开目标文件*/
   {
      printf("can not open output file \n");
      exit(0);
   }
   while(!feof(sfp))   /*读文件直到文件尾*/
   {
      if(1!=fread(p,sizeof(STUDENT),1,sfp))
     break; /*块读*/
      fwrite(p,sizeof(STUDENT),1,tfp);   /*块写*/
   }
   fclose(sfp);    /*关闭源文件*/
   fclose(tfp);   /*关闭目标文件*/
   printf("you have success copy  file!!!\n");   /*显示成功拷贝*/
}
/*排序*/
STUDENT *sort(STUDENT *h)
{
   int i=0;                  /*保存名次*/
   STUDENT *p,*q,*t,*h1;   /*定义临时指针*/
   h1=h->next;           /*将原表的头指针所指的下一个结点作头指针*/
   h->next=NULL;        /*第一个结点为新表的头结点*/
   while(h1!=NULL)    /*当原表不为空时,进行排序*/
   {
      t=h1;            /*取原表的头结点*/
      h1=h1->next;     /*原表头结点指针后移*/
      p=h;           /*设定移动指针p,从头指针开始*/
      q=h;         /*设定移动指针q做为p的前驱,初值为头指针*/
      while(t->sum<p->sum&&p!=NULL)  /*作总分比较*/
      {
     q=p;            /*待排序点值小,则新表指针后移*/
     p=p->next;
      }
      if(p==q)      /*p==q,说明待排序点值大,应排在首位*/
      {
     t->next=p;     /*待排序点的后继为p*/
     h=t;         /*新头结点为待排序点*/
      }
      else    /*待排序点应插入在中间某个位置q和p之间,如p为空则是尾部*/
      {
     t->next=p;   /*t的后继是p*/
     q->next=t;    /*q的后继是t*/
      }
   }
   p=h;               /*已排好序的头指针赋给p,准备填写名次*/
   while(p!=NULL)  /*当p不为空时,进行下列操作*/
   {
      i++;       /*结点序号*/
      p->order=i;   /*将名次赋值*/
      p=p->next;   /*指针后移*/
   }
   printf("sort sucess!!!\n");   /*排序成功*/
   return h;      /*返回头指针*/
}
/*计算总分和均值*/
void computer(STUDENT *h)
{
   STUDENT *p;   /*定义移动指针*/
   int i=0;  /*保存记录条数初值为0*/
   long s=0;   /*总分初值为0*/
   float average=0;  /*均分初值为0*/
   p=h;        /*从头指针开始*/
   while(p!=NULL)    /*当p不为空时处理*/
   {
      s+=p->sum;    /*累加总分*/
      i++;         /*统计记录条数*/
      p=p->next;   /*指针后移*/
   }
   average=(float)s/i;/* 求均分,均分为浮点数,总分为整数,所以做类型转换*/
   printf("\n--All students sum score is:%ld  average is %5.2f\n",s,average);
}
/*索引*/
STUDENT *index(STUDENT *h)
{
   STUDENT *p,*q,*t,*h1;  /*定义临时指针*/
   h1=h->next;    /*将原表的头指针所指的下一个结点作头指针*/
   h->next=NULL;   /*第一个结点为新表的头结点*/
   while(h1!=NULL)  /*当原表不为空时,进行排序*/
   {
      t=h1;        /*取原表的头结点*/
      h1=h1->next;   /*原表头结点指针后移*/
      p=h;   /*设定移动指针p,从头指针开始*/
      q=h;   /*设定移动指针q做为p的前驱,初值为头指针*/
      while(strcmp(t->no,p->no)>0&&p!=NULL)  /*作学号比较*/
      {
     q=p;           /*待排序点值大,应往后插,所以新表指针后移*/
     p=p->next;
      }
      if(p==q)   /*p==q,说明待排序点值小,应排在首位*/
      {
     t->next=p;  /*待排序点的后继为p*/
     h=t;    /*新头结点为待排序点*/
      }
      else     /*待排序点应插入在中间某个位置q和p之间,如p为空则是尾部*/
      {
     t->next=p;    /*t的后继是p*/
     q->next=t;     /*q的后继是t*/
      }
   }
   printf("index sucess!!!\n");  /*索引排序成功*/
   return h;    /*返回头指针*/
}
/*分类合计*/
void total(STUDENT *h)
{
   STUDENT *p,*q;   /*定义临时指针变量*/
   char sno[9],qno[9],*ptr;    /*保存班级号的*/
   float s1,ave;        /*保存总分和均分*/
   int i;       /*保存班级人数*/
   clrscr();    /*清屏*/
   printf("\n\n  *******************Total*****************\n");
   printf("---class---------sum--------------average----\n");
   p=h;       /*从头指针开始*/
   while(p!=NULL)  /*当p不为空时做下面的处理*/
   {
      memcpy(sno,p->no,8);  /*从学号中取出班级号*/
      sno[8]='\0';          /*做字符串结束标记*/
      q=p->next;        /*将指针指向待比较的记录*/
      s1=p->sum;      /*当前班级的总分初值为该班级的第一条记录总分*/
      ave=p->average;  /*当前班级的均分初值为该班级的第一条记录均分*/
      i=1;          /*统计当前班级人数*/
      while(q!=NULL)   /*内循环开始*/
      {
     memcpy(qno,q->no,8);   /*读取班级号*/
     qno[8]='\0';     /*做字符串结束标记*/
     if(strcmp(qno,sno)==0)  /*比较班级号*/
     {
        s1+=q->sum;     /*累加总分*/
        ave+=q->average; /*累加均分*/
        i++;         /*累加班级人数*/
        q=q->next;   /*指针指向下一条记录*/
     }
     else
        break;  /*不是一个班级的结束本次内循环*/
      }
      printf("%s     %10.2f           %5.2f\n",sno,s1,ave/i);
      if(q==NULL)
     break;   /*如果当前指针为空,外循环结束,程序结束*/
      else
     p=q;   /*否则,将当前记录作为新的班级的第一条记录开始新的比较*/
   }
   printf("---------------------------------------------\n");
}这个怎么改啊...一开始就是说内存函数..mem.h错误,,我很无语..

[ 本帖最后由 哎呀东东 于 2011-6-8 12:42 编辑 ]
搜索更多相关主题的帖子: C语言 结构体 管理系统 
2011-06-07 16:25
bccn_2012
Rank: 6Rank: 6
等 级:侠之大者
帖 子:158
专家分:447
注 册:2011-5-14
收藏
得分:10 
看看这个吧
https://bbs.bccn.net/thread-342098-1-1.html

用结构体数组就能做。
2011-06-07 16:29
bccn_2012
Rank: 6Rank: 6
等 级:侠之大者
帖 子:158
专家分:447
注 册:2011-5-14
收藏
得分:0 
看看这个吧
https://bbs.bccn.net/thread-342098-1-1.html

用结构体数组就能做。
2011-06-07 16:29
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:0 
程序代码:
#include<stdio.h>
struct student
{
    int num;
    char name[10];
    float math,yuwen,english,huaxue,physic,shengw;
    float sum1,average;
}stu[20];
void main()
{
    void sort(struct student*p);
    struct student*p1=stu;
    int i;
    float sum,aver;
    /*
    1
    sdfsdf
    1 2 3 4 5 6
    2
    sdfsgg
    2 3 4 5 6 7
    3
    sdflkj
    4 5 6 7 8 9
    */
    for(p1=stu;p1<stu+3;p1++)
    {
        printf("学号:");
        scanf("%d",&p1->num);
        getchar();
        printf("姓名:");
        scanf("%s",p1->name);
        printf("各门成绩:");
        scanf("%f %f %f %f %f %f",&p1->math,&p1->yuwen,&p1->english,&p1->huaxue,&p1->physic,&p1->shengw);
    }
    for(p1=stu;p1<stu+3;p1++)
    {
        p1->sum1=p1->math+p1->yuwen+p1->english+p1->huaxue+p1->physic+p1->shengw;
        printf("总分:%f",p1->sum1);
        p1->average=p1->sum1/6;
        printf("平均分:%f",p1->average);
        printf("\n");
    }
    printf("\n");
    sort(stu);
    for(p1=stu;p1<stu+3;p1++)
        printf("%-5d %s %-5.1f %-5.1f %-5.1f %-5.1f %-5.1f %-5.1f\n",p1->num,p1->name,p1->math,p1->yuwen,p1->english,p1->huaxue,p1->physic,p1->shengw);
}
void sort(struct student*p)
{
    int i,j;
    student swap;
    for(i=0;i<19;i++)
        for(j=i+1;j<20;j++)
            if(p[i].sum1<p[j].sum1)
            {
                swap=p[i];
                p[i]=p[j];
                p[j]=swap;
            }
}
今天下午很奇怪  怎么全是学生管理系统阿

                                         
===========深入<----------------->浅出============
2011-06-07 16:38
bccn_2012
Rank: 6Rank: 6
等 级:侠之大者
帖 子:158
专家分:447
注 册:2011-5-14
收藏
得分:0 
回复 4楼 laoyang103
时近期末, 要做课程设计的多了。

呵呵。
2011-06-07 16:43
bccn_2012
Rank: 6Rank: 6
等 级:侠之大者
帖 子:158
专家分:447
注 册:2011-5-14
收藏
得分:0 
回复 4楼 laoyang103
时近期末, 要做课程设计的多了。

呵呵。
2011-06-07 16:43
烟雾中的迷茫
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
帖 子:621
专家分:1069
注 册:2011-2-9
收藏
得分:0 
回复 4楼 laoyang103
呵呵 老杨啊  这个管理系统都快管晕了碰到N次了
2011-06-07 18:15
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:0 
回复 7楼 烟雾中的迷茫
呵呵 期末了 课程设计了  这不我也该课程设计了

                                         
===========深入<----------------->浅出============
2011-06-07 18:40
哎呀东东
Rank: 1
等 级:新手上路
帖 子:10
专家分:1
注 册:2011-6-7
收藏
得分:0 
回复 4楼 laoyang103
帅哥,你这个相对简单了,我们要两个结构体数组(或链表,文件),还要对数据进行修改,每次执行完后还要能返回主菜单,我只能设计一个数组,两个就混了..拜谢啊
2011-06-08 12:22
bccn_2012
Rank: 6Rank: 6
等 级:侠之大者
帖 子:158
专家分:447
注 册:2011-5-14
收藏
得分:10 
程序代码:
#include "stdio.h"
#include "math.h"
int chaxun();
void luru();
int xiugai();
int shanchu();
void xianshi();
int i,j,g,a[100],b[100],h,c;

 
void main()
{  int k;
    printf("             欢迎使用成绩登记系统!                         \n");
    printf("          ---------------------------------------------------\n");
    printf("          请选择操作:   1  成绩录入         2  成绩查询     \n");
    printf("                         3  成绩修改         4  成绩删除     \n");
    printf("                         5  显示全部         0  退出系统     \n");
    printf("          ---------------------------------------------------\n");
    while(1)
    {    
    scanf("%d",&k);
   if (k==0)  break;
   else if(k<0||k>5) {printf("没有这个选项!请重新选择!\n"); 
    printf("          ---------------------------------------------------\n");
    printf("          请选择操作:   1  成绩录入         2  成绩查询     \n");
    printf("                         3  成绩修改         4  成绩删除     \n");
    printf("                         5  显示全部         0  退出系统     \n");
    printf("          ---------------------------------------------------\n");
    }
      
   else if(k==1) { luru(); 
    printf("          ---------------------------------------------------\n");
    printf("          请选择操作:   1  成绩录入         2  成绩查询     \n");
    printf("                         3  成绩修改         4  成绩删除     \n");
    printf("                         5  显示全部         0  退出系统     \n");
    printf("          ---------------------------------------------------\n");}
else if(k==2) {chaxun();
    printf("          ---------------------------------------------------\n");
    printf("          请选择操作:   1  成绩录入         2  成绩查询     \n");
    printf("                         3  成绩修改         4  成绩删除     \n");
    printf("                         5  显示全部         0  退出系统     \n");
    printf("          ---------------------------------------------------\n");}
    
else if(k==3)  { xiugai();
  
    printf("          ---------------------------------------------------\n");
    printf("          请选择操作:   1  成绩录入         2  成绩查询     \n");
    printf("                         3  成绩修改         4  成绩删除     \n");
    printf("                         5  显示全部         0  退出系统     \n");
    printf("          ---------------------------------------------------\n");}
    
    else if(k==4)  {shanchu();
    printf("          ---------------------------------------------------\n");
    printf("          请选择操作:   1  成绩录入         2  成绩查询     \n");
    printf("                         3  成绩修改         4  成绩删除     \n");
    printf("                         5  显示全部         0  退出系统     \n");
    printf("          ---------------------------------------------------\n");}


else if(k==5)  {xianshi();
    printf("          ---------------------------------------------------\n");
    printf("          请选择操作:   1  成绩录入         2  成绩查询     \n");
    printf("                         3  成绩修改         4  成绩删除     \n");
    printf("                         5  显示全部         0  退出系统     \n");
    printf("          ---------------------------------------------------\n");}

    }
}

void luru()
{
  printf("请依序输入学号(以-1结束):\n");
  for(i=0;i<100;i++)
  {scanf("%d",&a[i]);
   if(a[i]==-1) break;
  }
printf("请依序输入成绩:\n");
for(j=0;j<i;j++)
{scanf("%d",&b[j]);
if(b[j]<0){printf("输入错误!请重新输入!\n");continue; };
if(j==i-1) break;
}
printf("输入成功!\n");
}


int chaxun()
{ int x,y;
  printf("请输入要查询的学号:");
  scanf("%d",&x);
  while(x>0)
  {
  for(y=0;y<i;y++)
  {  if(x==a[y]){ printf("该学生的成绩为:%d\n",b[y]);
  
  return 1;}
  }
   printf("没有您要查询的记录!\n");

 return 0;
  }

 return 0;
}

int xiugai()
{ int x;
  printf("请输入要修改成绩的学号:");
  scanf("%d",&h);
  while(h>0)
  {
  for(g=0;g<i;g++)
   if(h==a[g]) 
   { printf("请输入新的成绩:");
        scanf("%d",&x);  
        if(x>0){  b[g]=x ;    printf("修改成功!\n");return 1;}
        else {printf("输入错误!\n"); return 0;}
        }
   break;
  }

 printf("您输入的学号错误!\n");

 return 0;
}

int shanchu()
{    
  printf("请输入要删除成绩的学号:");
  scanf("%d",&h);
  while(h>0)
  {
  for(g=0;g<i;g++)
  {  if(h==a[g]) { b[g]=0; printf("删除成功!\n") ;return 1 ;}
      }
break;
  }

 printf("您输入的学号错误!\n");

 return 0;
}

void xianshi()
{   int x;
     
     printf("      学号    成绩  \n");
     for(x=0;x<i;x++)
         printf("      %4d%6d\n",a[x],b[x]);}


这个以前写的,改改应该可以。
2011-06-08 12:59
快速回复:这里有个很难的题目,请指教!!
数据加载中...
 
   



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

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