鱼C论坛

 找回密码
 立即注册
查看: 2542|回复: 3

求大侠帮忙

[复制链接]
发表于 2011-8-10 16:28:24 | 显示全部楼层 |阅读模式

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

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

x
  1. #include "stdio.h"
  2. #include "stdlib.h"
  3. #include "string.h"
  4. #define LEN sizeof(struct student)
  5. struct student
  6. {
  7.         char num[6], name[20], sex[3];//定义学号、姓名、性别
  8.         float math, english, politics, chinese, sum;//定义数学、英语、**、语文、总分
  9.         struct student *next;
  10. };

  11. int n;//全局变量,用于记录每个班级学生人数

  12. void menu()
  13. {
  14.         system("cls");//清屏
  15.         printf("-------------------------------------------------------------------------------");
  16.         printf("\n                                 学生数据管理系统\n");
  17.         printf("\n                         [0]退出\n");
  18.         printf("\n                         [1]创建学生数据\n");
  19.         printf("\n                         [2]添加学生数据\n");
  20.         printf("\n                         [3]删除学生数据\n");
  21.         printf("\n                         [4]查询\n");
  22.         printf("-------------------------------------------------------------------------------");
  23.        
  24. }

  25. // 等待用户按回车后回到主菜单
  26. void to_menu()
  27. {
  28. char c1, c2;
  29. printf("\n\n\n按回车键返回主菜单...");
  30. scanf("%c%c",&c1,&c2);//第一个字符吸收上次的确认回车键
  31. menu();
  32. }

  33. //排序
  34. void *sort(struct student *head)
  35. {
  36.         struct student *first, *tail, *p_min, *min, *p;//分别是排列后的有序链的表头指针、排列后的有序链的表尾指针、保留键值更小的前驱借点的指针、存储最小节点、当前比较的节点
  37.         first = NULL;
  38.         while(head != NULL) //在链表中找键值最小的节点
  39.         {
  40.                 for(p = head, min = head;p->next != NULL;p = p = p->next)//遍历链表中的节点,找出此时最小的节点
  41.                 {
  42.                         if((strcmp(p->next->num, min->num)) < 0)//找到一个比当前min小的节点
  43.                         {
  44.                                 p_min = p;//保存找到节点的前驱节点:显然p->next的前驱节点是p。
  45.                                 min = p->next;//保存键值更小的节点。
  46.                         }
  47.                 }
  48.                 if(first == NULL)/*如果有序链表目前还是一个空链表*/
  49.                 {
  50.                         first = min;/*第一次找到键值最小的节点。*/
  51.                         tail = min;/*注意:尾指针让它指向最后的一个节点。*/
  52.                 }
  53.                 else /*有序链表中已经有节点*/
  54.                 {
  55.                         tail->next = min;/*把刚找到的最小节点放到最后,即让尾指针的next指向它。*/
  56.                         tail = min;/*尾指针也要指向它。*/
  57.                 }
  58.                 if(min == head) /*如果找到的最小节点就是第一个节点*/
  59.                 {
  60.                         head = head->next; /*显然让head指向原head->next,即第二个节点,就OK*/
  61.                 }
  62.                 else /*如果不是第一个节点*/
  63.                 {
  64.                         p_min->next = min->next; /*前次最小节点的next指向当前min的next,这样就让min离开了原链表。*/
  65.                 }
  66.         }
  67.         if(first != NULL) /*循环结束得到有序链表first*/
  68.         {
  69.                 tail->next = NULL;/*单向链表的最后一个节点的next应该指向NULL*/
  70.         }
  71.         head = first;
  72.         return head;
  73. }

  74. //打印
  75. void list(struct student *head, char c_name[20])
  76. {
  77.         struct student *p;
  78.         p  = head;
  79.         system("cls");
  80.         printf("\n---------------------------[%s]学生成绩表----------------------------\n",c_name);
  81.         printf("\n\t学号\t姓名\t性别\t数学\t英语\t**\t语文\t总分\n");
  82.         while(p != NULL)
  83.         {
  84.                 printf("\n\t%s\t%s\t%s\t%.1f\t%.1f\t%.1f\t%.1f\t%.1f\n",p->num,p->name,p->sex,p->math,p->english,p->politics,p->chinese,p->sum);
  85.                 p = p->next;
  86.         }
  87.         printf("\n班级共%d名学生!",n);
  88. }

  89. //保存
  90. void save_data(struct student *head, char c_name[20])
  91. {
  92.         FILE *fp;
  93.         struct student *p;
  94.         p = head;
  95.         if((fp = fopen(c_name,"wb")) == NULL)
  96.         {
  97.                 printf("\n不能保存指定文件!");
  98.                 exit(0);
  99.         }
  100.         while(p->next != NULL)//当next等于NULL时表明已经是最后一块数据,退出
  101.         {
  102.                 fwrite(p, sizeof(struct student), 1, fp);
  103.                 p = p->next;
  104.         }
  105.         fclose(fp);
  106.         list(head, c_name);
  107. }

  108. //载入
  109. void *load_data(char c_name[20])
  110. {
  111.         FILE *fp;
  112.         struct student *p, *last, *head;//p工作指针、last最后一项指针、head头指针
  113.         if((fp = fopen(c_name,"rb")) == NULL)
  114.         {
  115.                 printf("\n不能打开指定文件!");
  116.                 return NULL;//如果文件不存在或无法打开返回空地址
  117.         }
  118.         head = (struct student *)malloc(LEN);
  119.         last = head;
  120.         while(!feof(fp))
  121.         {
  122.                 p = (struct student *)malloc(LEN);
  123.                 if((fread(p, sizeof(struct student), 1, fp)) == 1)
  124.                 {
  125.                         last->next = p;
  126.                         last = p;
  127.                 }
  128.         }
  129.         fclose(fp);
  130.         last->next = NULL;//表示文件结束
  131.         return head = head->next;
  132. }
  133. void add_data()
  134. {
  135.         FILE *fp;
  136.         struct student *p1,*p2,*head;
  137.         char c_name[20];//存放班级名
  138.         char ch1, ch2;//判定是否继续输入学生信息

  139.         n = 0;

  140.         printf("\n请输入班级名:");
  141.         scanf("%s",c_name);
  142.         fp = fopen(c_name,"wb");//创建班级数据文件
  143.         //head = NULL;
  144.         while(ch2 != '0')
  145.         {       
  146.                 n++;
  147.                 if(n == 1)
  148.                 {
  149.                         p1 =  (struct student *)malloc(LEN);
  150.                         printf("\n学号:");
  151.                         scanf("%s",p1->num);
  152.                         printf("\n姓名:");
  153.                         scanf("%s",p1->name);
  154.                         printf("\n性别:");
  155.                         scanf("%s",p1->sex);
  156.                         printf("\n数学成绩:");
  157.                         scanf("%f",&p1->math);
  158.                         printf("\n英语成绩:");
  159.                         scanf("%f",&p1->english);
  160.                         printf("\n**:");
  161.                         scanf("%f",&p1->politics);
  162.                         printf("\n语文成绩:");
  163.                         scanf("%f",&p1->chinese);
  164.                         p1->sum = p1->math + p1->english + p1->politics + p1->chinese;
  165.                         printf("\n学号\t姓名\t性别\t数学\t英语\t**\t语文\t总分\n");
  166.                         printf("------------------------------------------------------------\n");
  167.                         printf("%s\t%s\t%s\t%.1f\t%.1f\t%.1f\t%.1f\t%.1f\n",p1->num, p1->name, p1->sex, p1->math, p1->english, p1->politics, p1->chinese, p1->sum);
  168.                         head = p1;
  169.                         p1->next = NULL;
  170.                         LOOP1: printf("\n按0结束,回车继续输入!\n");
  171.                         printf("\n请输入:");
  172.                         scanf("%c%c",&ch1,&ch2);
  173.                         if( ch2 != '0' && ch2 != '\n')//判断如果输入的字符不为0或回车,报错并从新输入
  174.                         {
  175.                                 printf("\n输入错误!请从新输入!");
  176.                                 goto LOOP1;
  177.                         }
  178.                 }
  179.                 else
  180.                 {
  181.                         p2 = p1;
  182.                         p1 = (struct student *)malloc(LEN);
  183.                         printf("\n学号:");
  184.                         scanf("%s",p1->num);
  185.                         printf("\n姓名:");
  186.                         scanf("%s",p1->name);
  187.                         printf("\n性别:");
  188.                         scanf("%s",p1->sex);
  189.                         printf("\n数学成绩:");
  190.                         scanf("%f",&p1->math);
  191.                         printf("\n英语成绩:");
  192.                         scanf("%f",&p1->english);
  193.                         printf("\n**:");
  194.                         scanf("%f",&p1->politics);
  195.                         printf("\n语文成绩:");
  196.                         scanf("%f",&p1->chinese);
  197.                         p1->sum = p1->math + p1->english + p1->politics + p1->chinese;
  198.                         printf("\n学号\t姓名\t性别\t数学\t英语\t**\t语文\t总分\n");
  199.                         printf("------------------------------------------------------------\n");
  200.                         printf("%s\t%s\t%s\t%.1f\t%.1f\t%.1f\t%.1f\t%.1f\n",p1->num, p1->name, p1->sex, p1->math, p1->english, p1->politics, p1->chinese, p1->sum);
  201.                         p2->next = p1;
  202.                         LOOP2: printf("\n按0结束,回车继续输入!\n");
  203.                         printf("\n请输入:");
  204.                         scanf("%c%c",&ch1,&ch2);
  205.                         if( ch2 != '0' && ch2 != '\n')//判断如果输入的字符不为0或回车,报错并从新输入
  206.                         {
  207.                                 printf("\n输入错误!请从新输入!");
  208.                                 goto LOOP2;
  209.                         }
  210.                 }
  211.         }
  212.         p1->next= NULL;
  213.         fclose(fp);
  214.         save_data(head,c_name);
  215. }

  216. //添加数据
  217. void insert()
  218. {
  219.         char c_name[20];
  220.         struct student *fun;//用于判断要打开的文件是否存在
  221.         struct student *p, *head;
  222.         LOOP3 : printf("\n请输入要插入数据的班级名:");
  223.         scanf("%s",c_name);
  224.         fun = load_data(c_name);
  225.         if(fun == NULL)
  226.         {
  227.                 printf("\n请从新输入!");
  228.                 goto LOOP3;
  229.         }
  230.         head = fun;//把头指针赋给head
  231.         p = (struct student *)malloc(LEN);//开辟存储单元
  232.         printf("\n学号:");
  233.         scanf("%s",&p->num);
  234.         printf("\n姓名:");
  235.         scanf("%s",&p->name);
  236.         printf("\n性别:");
  237.         scanf("%s",&p->sex);
  238.         printf("\n数学成绩:");
  239.         scanf("%f",&p->math);
  240.         printf("\n英语成绩:");
  241.         scanf("%f",&p->english);
  242.         printf("\n**:");
  243.         scanf("%f",&p->politics);
  244.         printf("\n语文成绩:");
  245.         scanf("%f",&p->chinese);
  246.         p->sum = p->math + p->english + p->politics + p->chinese;
  247.         p->next = head;
  248.         head = p;
  249.         head = sort(head);
  250.         n++;
  251.         save_data(head, c_name);
  252. }

  253. void main()
  254. {
  255.         char fun;
  256.         menu();

  257.         while(1)
  258.         {
  259.                 printf("请输入功能号[0-4]:");
  260.                 scanf("%c",&fun);
  261.                 switch(fun)
  262.                 {
  263.                         case '0': break;
  264.                         case '1':
  265.                         {
  266.                                 add_data();
  267.                                 to_menu();
  268.                         }
  269.                         case '2':
  270.                         {
  271.                                 insert();
  272.                         }
  273.                 }
  274.                 if(fun == '0')
  275.                 {
  276.                         break;
  277.                 }
  278.         }
  279. }
复制代码
求大侠帮忙看看程序  编译无错误 但是 添加数据那里有问题 我还不知道是哪里的问题 请大侠们耐心看看 帮小弟找找错误 我实在是找不出来了 !!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
 楼主| 发表于 2011-8-10 17:28:55 | 显示全部楼层
没人帮看看呀
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2011-8-12 10:53:43 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2011-8-18 17:24:02 | 显示全部楼层
#include "stdio.h"

#include "stdlib.h"

#include "string.h"

#define LEN sizeof(struct student)

struct student

{
        char num[6], name[20], sex[3];//定义学号、姓名、性别

       float math, english, politics, chinese, sum;//定义数学、英语、**、语文、总分

       struct student *next;

};
int n;//全局变量,用于记录每个班级学生人数
void menu()

{

       system("cls");//清屏

                printf("-------------------------------------------------------------------------------");
                printf("\n                                 学生数据管理系统\n");
                printf("\n                         [0]退出\n");
                printf("\n                         [1]创建学生数据\n");
                printf("\n                         [2]添加学生数据\n");
                printf("\n                         [3]删除学生数据\n");
                printf("\n                         [4]查询\n");

                printf("-------------------------------------------------------------------------------");

      

}
// 等待用户按回车后回到主菜单

void to_menu()

{
        char c1, c2;

        printf("\n\n\n按回车键返回主菜单...");

        scanf("%c%c",&c1,&c2);//第一个字符吸收上次的确认回车键

        menu();

}
//排序

struct student *sort(struct student *head)

{

      struct student *first, *tail, *p_min, *min, *p;//分别是排列后的有序链的表头指针、排列后的有序链的表尾指针、保留键值更小的前驱借点的指针、存储最小节点、当前比较的节点

      first = NULL;

     while(head != NULL) //在链表中找键值最小的节点

     {

              for(p = head, min = head;p->next != NULL;p = p = p->next)//遍历链表中的节点,找出此时最小的节点

              {

                      if((strcmp(p->next->num, min->num)) < 0)//找到一个比当前min小的节点

                                        {
                                                        p_min = p;//保存找到节点的前驱节点:显然p->next的前驱节点是p。

                             min = p->next;//保存键值更小的节点。

                     }

               }

               if(first == NULL)/*如果有序链表目前还是一个空链表*/

               {

                       first = min;/*第一次找到键值最小的节点。*/

                      tail = min;/*注意:尾指针让它指向最后的一个节点。*/

              }

               else /*有序链表中已经有节点*/

                {

                       tail->next = min;/*把刚找到的最小节点放到最后,即让尾指针的next指向它。*/

                       tail = min;/*尾指针也要指向它。*/

             }

              if(min == head) /*如果找到的最小节点就是第一个节点*/

              {

                       head = head->next; /*显然让head指向原head->next,即第二个节点,就OK*/

           }

         else /*如果不是第一个节点*/

               {

                       p_min->next = min->next; /*前次最小节点的next指向当前min的next,这样就让min离开了原链表。*/
               }

    }
       if(first != NULL) /*循环结束得到有序链表first*/

       {

               tail->next = NULL;/*单向链表的最后一个节点的next应该指向NULL*/

                }

                head = first;

       return head;

}
//打印

void list(struct student *head, char c_name[20])

{

       struct student *p;

      p  = head;

      system("cls");

        printf("\n---------------------------[%s]学生成绩表----------------------------\n",c_name);
      printf("\n\t学号\t姓名\t性别\t数学\t英语\t**\t语文\t总分\n");

       while(p != NULL)

       {

             printf("\n\t%s\t%s\t%s\t%.1f\t%.1f\t%.1f\t%.1f\t%.1f\n",p->num,p->name,p->sex,p->math,p->english,p->politics,p->chinese,p->sum);

             p = p->next;

        }

        printf("\n班级共%d名学生!",n);

}


//保存

void save_data(struct student *head,char c_name[20])

{
       
      FILE *fp;

      struct student *p;

      p = head;

       if((fp = fopen(c_name,"wb")) == NULL)

       {

                printf("\n不能保存指定文件!");

               exit(0);

        }
           while(p)//当next等于NULL时表明已经是最后一块数据,退出

        {
                   fwrite(p, sizeof(struct student), 1, fp);
                  
                p = p->next;
           }

        fclose(fp);

       list(head, c_name);
}



//载入




struct student *load_data(char c_name[20])

{
       FILE *fp;

        struct student *p, *last, *head;//p工作指针、last最后一项指针、head头指针
        if((fp = fopen(c_name,"rb")) == NULL)
        {

                printf("\n不能打开指定文件!");

               return NULL;//如果文件不存在或无法打开返回空地址
        }

        head = (struct student *)malloc(LEN);

        last = head;

       while(!feof(fp))

      {
             p = (struct student *)malloc(LEN);

             if((fread(p, sizeof(struct student), 1, fp)) == 1)

                {

                       last->next = p;

                       last = p;

               }

        }

        fclose(fp);

        last->next = NULL;//表示文件结束

       return head = head->next;

}

void add_data()

{

       FILE *fp;

        struct student *p1,*p2,*head;

       char c_name[20];//存放班级名

       char ch1, ch2;//判定是否继续输入学生信息
                n = 0;
                printf("\n请输入班级名:");

       scanf("%s",c_name);

        //fp= fopen(c_name,"wt");//创建班级数据文件

       //head = NULL;

       while(ch2 != '0')

        {        

               n++;

             if(n == 1)

               {

                       p1 =  (struct student *)malloc(LEN);

                      printf("\n学号:");

                        scanf("%s",p1->num);

                       printf("\n姓名:");

                      scanf("%s",p1->name);

                        printf("\n性别:");

                       scanf("%s",p1->sex);

                      printf("\n数学成绩:");

                       scanf("%f",&p1->math);

                        printf("\n英语成绩:");

                        scanf("%f",&p1->english);

                        printf("\nC语言成绩:");

                        scanf("%f",&p1->politics);

                       printf("\n语文成绩:");
                       scanf("%f",&p1->chinese);

                        p1->sum = p1->math + p1->english + p1->politics + p1->chinese;

                       printf("\n学号\t姓名\t性别\t数学\t英语\t**\t语文\t总分\n");

                      printf("------------------------------------------------------------\n");

                       printf("%s\t%s\t%s\t%.1f\t%.1f\t%.1f\t%.1f\t%.1f\n",p1->num, p1->name, p1->sex, p1->math, p1->english, p1->politics, p1->chinese, p1->sum);

                      head = p1;

                      p1->next = NULL;

                       LOOP1: printf("\n按0结束,回车继续输入!\n");

                     printf("\n请输入:");

                       scanf("%c%c",&ch1,&ch2);

                       if( ch2 != '0' && ch2 != '\n')//判断如果输入的字符不为0或回车,报错并从新输入

                       {
                                                        printf("\n输入错误!请从新输入!");
                                                        goto LOOP1;
                      }

              }

               else

                {                p2 = p1;

                       p1 = (struct student *)malloc(LEN);

                      printf("\n学号:");

                       scanf("%s",p1->num);
                       printf("\n姓名:");

                        scanf("%s",p1->name);

                      printf("\n性别:");

                       scanf("%s",p1->sex);
                       printf("\n数学成绩:");
                       scanf("%f",&p1->math);

                       printf("\n英语成绩:");

                       scanf("%f",&p1->english);
                       printf("\C语言成绩:");

                       scanf("%f",&p1->politics);
                       printf("\n语文成绩:");

                     scanf("%f",&p1->chinese);

                      p1->sum = p1->math + p1->english + p1->politics + p1->chinese;

                     printf("\n学号\t姓名\t性别\t数学\t英语\t**\t语文\t总分\n");

                       printf("------------------------------------------------------------\n");

                  printf("%s\t%s\t%s\t%.1f\t%.1f\t%.1f\t%.1f\t%.1f\n",p1->num, p1->name, p1->sex, p1->math, p1->english, p1->politics, p1->chinese, p1->sum);

                       p2->next = p1;

                      LOOP2: printf("\n按0结束,回车继续输入!\n");

                     printf("\n请输入:");

                       scanf("%c%c",&ch1,&ch2);

                      if( ch2 != '0' && ch2 != '\n')//判断如果输入的字符不为0或回车,报错并从新输入

                        {
                                                  printf("\n输入错误!请从新输入!");

                              goto LOOP2;
                                                }
                     

               }

        }

                p1->next= NULL;
                save_data(head,c_name);

}



//添加数据

void insert()

{

      char c_name[20];

        struct student *fun;//用于判断要打开的文件是否存在

        struct student *p, *head;

        LOOP3 : printf("\n请输入要插入数据的班级名:");
        scanf("%s",c_name);

        fun = load_data(c_name);

        if(fun == NULL)

        {

               printf("\n请从新输入!");

                goto LOOP3;

      }

      head = fun;//把头指针赋给head

        p = (struct student *)malloc(LEN);//开辟存储单元
       printf("\n学号:");

       scanf("%s",&p->num);

        printf("\n姓名:");

        scanf("%s",&p->name);

        printf("\n性别:");

       scanf("%s",&p->sex);

      printf("\n数学成绩:");

      scanf("%f",&p->math);

        printf("\n英语成绩:");

      scanf("%f",&p->english);

        printf("\n**:");

       scanf("%f",&p->politics);

       printf("\n语文成绩:");

       scanf("%f",&p->chinese);

       p->sum = p->math + p->english + p->politics + p->chinese;

       p->next = head;

       head = p;

       head = sort(head);

       n++;

       save_data(head, c_name);

}



void main()

{

       char fun;

        menu();



       while(1)

       {

              printf("请输入功能号[0-4]:");

               scanf("%c",&fun);

              switch(fun)

               {
                                        case '0': break;

                                        case '1':

                                        {
                                           add_data();

                                                to_menu();

                                                break;
                                        }

                                        case '2':

                                        {
                                                insert();
                                                break;

                                        }

              }

                if(fun == 0)

              {

                       break;

              }

      }

}
给你弄好了,自己运行一下!那个sava_data()函数中往文件中写数据的时候那个while循环有点儿问题,还有主函数中需要修改几个地方,自己看看!!对照一下!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2024-4-24 04:17

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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