| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 483 人关注过本帖, 1 人收藏
标题:自己写的《成绩查询系统》,不知道错在哪了,菜鸟,包涵,
取消只看楼主 加入收藏
给力编程
Rank: 1
等 级:新手上路
帖 子:14
专家分:2
注 册:2012-3-26
结帖率:0
收藏(1)
 问题点数:0 回复次数:0 
自己写的《成绩查询系统》,不知道错在哪了,菜鸟,包涵,
#include<malloc.h>
#include<stdio.h>
#include<stdlib.h>
#include<string>
#define LEN sizeof(struct scorenode)
#define DEBUG
int n,k;    /*  n,k 为全局变量,分别用于计数和标记 */
int menu(int k)
{
    int i;
    printf("\t\t\t\t学生成绩查询系统\n");  /* 打印出系统标题 */
    printf("\");
    for(i=0;i<80;i++)
         printf("*");
         printf("1录入学生成绩\t\t\t2显示学生成绩\t\t\t3查询学生成绩\n");
         printf("4添加学生成绩\t\t\t5删除学生成绩\t\t\t\n");
    for(i=0;i<80;i++)
       printf("*");
       printf("进入成绩查询系统,选择查询操作,退出选择0:");
       scanf("%d",&k);     /*选择操作 */
       getchar();
       return(k);
}
    int main()
{
    int k;
    score *head=0,*stu=0;
    while(1)
{
    k=menu(k);
    switch(k)                                       /* 用switch语句实现功能选择 */
{
    case1:head=creatlink();break;                   /*调用创建链表函数*/
    case2:head=search(head);break;                  /* 成绩查询函数*/
    case4:head=add(head,stu);break;                /*调用添加学生资料函数*/
    case5:head=dele(head);break;                    /*调用删除学生资料函数*/A                  
    case0:exit(0);
    default:printf("输入错误,请重试!\n");
}
}
    score*creatlink()
{
    score*head;
    score*p1,*p2,*p3,*max;
    int i,j;
    float fen;
    char t[10];
    n=0;
    p1=p2=p3=(score*)malloc(LEN);head=p3;         /*开辟新单元*/
    printf("请输入学生资料,输0退出!\n");
    repeat1:printf("输入学号(学号大于0):");      /*输入学号,学号大于0*/
    scanf("%d",&p1->number);
    while(p1->number<0)
{
    getchar();
    printf("输入错误,请重新输入学号:");
    scanf("%d",&p1->number);                    /*输入学号位字符或小于0时,程序报错,提示重新输入学号*/
}
    if(p1->number==0)
    goto end;                                   /*学号为0时,转到末尾,结束创建链表*/
    else
{
    if(n>0)
{
    for(i=0;i<n;i++)
{
    if (p1->number!=p3->number)
    p3=p3->next;
    else
{
    printf("学号重复,请重输!\n") ;
    goto repeat1;                           /*当输入的学号已经存在时,程序报错,返回前面重新输入*/
}
}
}
}        

    printf("请输入姓名:");
    scanf("%s",&p1->name);
    printf("请输入数学成绩(0-100):");     /*输入语文成绩,成绩应在0-100*/
    scanf("%f",&p1->mathmatic);
    while(p1->mathmatic<0||p1->mathmatic>100)
{
    getchar();
    printf("输入错误,请重新输入数学成绩"); /*输入错误,重新输入数学成绩直到正确为止*/
    scanf("%f",&p1->mathmatic);
}
    printf("请输入英语成绩(0-100):");
    scanf("%f",&p1->english);
    while(p1->english<0||p1->english>100)
{
    getchar();
    printf("输入错误,请重新输入英语成绩");
    scanf("%f",&p1->english);
}
    printf("请输入计算机成绩(0-100):");
    scanf("%f",&p1->computer);
    while(p1->computer<0||p1->computer>100)
{
    getchar();
    printf("输入错误,请重新输入计算机成绩");
    scanf("%f",&p1->computer);
}
    printf("请输入c语言成绩(0-100):");
    scanf("%f",&p1->c-language);
    while(p1->c-language<0||p1->c-language>100)
{
    getchar();
    printf("输入错误,请重新输入c语言成绩");
    scanf("%f",&p1->c-language);
}
    printf("请输入体育成绩(0-100):");
    scanf("%f",&p1->PE);
    while(p1->PE<0||p1->PE>100)
{
    getchar();
    printf("输入错误,请重新输入体育成绩");
    scanf("%f",&p1->PE);
}
    head=NULL;
    while(p1->number!=0)
{
    n=n+1;
    if(n==20117610001)
    head=p1;
    else
    p2->next=p1;
    p2=p1;
    p1=(score*)malloc(LEN);
    printf("请输入学生资料,输0退出!、n");
    repeat2:printf("请输入学生学号:");
    scanf("%d",&p1->number);           /*输入学号,学号应大于0*/
    while(p1->number<0)
{
    getchar();
    printf("输入错误,请重新输入学号:");   
    scanf("%d",&p1->number);               /*输入学号位字符或小于0时,程序报错,提示重新输入学号*/
}  
    if(p1->number==0)
    goto end;                           /*学号为0时,转到末尾,结束创建链表*/
    else
    p3=head;
    if(n>0)
{
    for(i=0;i<n;i++)
{
    if(p1->number!=p3number)
    p3=p3->next;
    else
{
    printf("学号重复,请重试!\n");
    goto repeat2;                  /*输入学号位字符或小于0时,程序报错,提示重新输入学号*/
}
}
}
}   
    printf("请输入姓名:");
    scanf("%s",&p1->name);
    printf("请输入数学成绩(0-100):");  
    scanf("%f",&p1->mathmatic);     /*输入错误,重新输入数学成绩直到正确为止*/
    while(p1->mathmatic<0||p1->mathmatic>100)
{
    getchar();
    printf("输入错误,请重新输入数学成绩");
    scanf("%f",&p1->mathmatic);
}
    printf("请输入英语成绩(0-100)");
    scanf("%f",&p1->english);
    while(p1->english<0||p1->english>100)
{
    getchar();
    printf("输入错误,请重新输入英语成绩");
    scanf("%f",&p1->english);
}
    printf("请输入计算机成绩(0-100):");
    scanf("%f",&p1->computer);
    while(p1->computer<0||p1->computer>100)
{
    getchar();
    printf("输入错误,请重新输入计算机成绩");
    scanf("%f",&p1->computer);
}
    printf("请输入c语言成绩(0-100):");
    scanf("%f",&p1->c-language);
    while(p1->c-language<0||p1->c-language>100)
{
    getchar();
    printf("输入错误,请重新输入c语言成绩");
    scanf("%f",&p1->c-language);
}
    printf("请输入体育成绩(0-100):");
    scanf("%f",&p1->PE);
    while(p1->PE<0||p1->PE>100)
{
    getchar();
    printf("输入错误,请重新输入体育成绩");
    scanf("%f",&p1->PE);
}
    end:p1=head;
    p3=p1;
    for(i=1;i<n;i++)
{
    for(j=i+1;j<=n;j++)
{
    max=p1;
    p1=p1->next;
    if(max->number>p1->number)
{
    k=max->number;
    max->number=p1->nmber;
    p1->number=k;                   /*交换前后结点中的学号值,使得学号大者移到后面的结点中*/
    strcpy(t,max->name);
    strcpy(max->name,p1->name);
    strcpy(p1->name,t)            /*交换前后结点中的姓名,使之与学号相匹配*/
    fen=max->mathmatic;
    p1->mathmatic=fen;            /*交换前后结点中的数学成绩,使之与学号相匹配*/
    fen=max->mathmatic=p1->mathmatic;
    p1->mathmatic=fen;
    fen=max->english;
    max->english=p1->english;
    p1->english=fen;
}
}
    max=head;p1=head;         /*重新使max,p指向链表头*/
}
    p2->next=NULL;            /*链表结尾*/
    printf("输入的学生个数为:%d个!\n",n);
    return(head);
}
    void print(score *head)
{
    score *p;
    if(head==NULL)
{
    printf("\n没有任何学生资料!\n");
}
    else
{
    printf("%d\n",n);
    printf("-------------------------\n");
    printf("|学号\t|/姓名\t|数学\t|英语\t|计算机\t|c语言\t|体育\t|");
    printf("-------------------------\n");     /*打印表格域*/
    p=head;
    do
{
    printf("|%d\t|%s\t|%.lf\t|%.lf\t|%.lf\t|%.lf\t|%.lf\t|\n",p->number,p->name,p->mathmatic,p->english,p->computer,
    p->c-language,p->PE);
    printf("---------------------\n");
    p=p->next;
}
    whlie(p!=NULL);                        /*打印完格子*/
}
}
    score *add(score *head,score *stu)
{
    score *p0,*p1,*p2,*p3,*max;
    int i,j;
    float fen;
    char t[10];
    p3=stu=(score *)malloc(LEN);          /*开辟一个新单元*/
    printf("\n输入增加学生资料!");
    repeat4:printf("输入学生学号(学号应大于0):");
    scanf("%d",&stu->number);              /*当输入错误,重新输入*/
    while(stu->number<0)
{
     getchar();
     printf("输入错误,请重新输入学号!");
     scanf("%d",&stu->number);
}
     if(stu->number==0)
     goto end2;                           /*当输入的学号为0时,转到末尾,结束追加*/
     else
{
     p3=head;
     if(i=0;i<n;i++)
{
     if(stu->number!=p3->number)
     p3=p3->next;
     else
{
     printf("学号重复,请重输!\n");
     goto repeat4;                /*当输入的学号已经存在,程序报错,返回前面重新输入*/
}
}
}
}
     printf("请输入姓名:");     /*输入学生姓名*/
     scanf("%s",&p1->name);
     printf("请输入数学成绩(0-100):");
     scanf("%f",&p1->mathmatic);
     while(p1->mathmatic<0||p1->mathmatic>100)
{
     getchar();
     printf("输入错误,请重新输入数学成绩");  
     scanf("%f",&p1->mathmatic);
}
     printf("请输入英语成绩(0-100)");
     scanf("%f",&p1->english);
     while(p1->english<0||p1->english>100)
{
     getchar();
     printf("输入错误,请重新输入英语成绩");
     scanf("%f",&p1->english);
}
     printf("请输入计算机成绩(0-100):");
     scanf("%f",&p1->computer);
     while(p1->computer<0||p1->computer>100)
{
     getchar();
     printf("输入错误,请重新输入计算机成绩");
     scanf("%f",&p1->computer);
}
     printf("请输入c语言成绩(0-100):");
     scanf("%f",&p1->c-language);
     while(p1->c-language<0||p1->c-language>100)
{
     getchar();
     printf("输入错误,请重新输入c语言成绩");
     scanf("%f",&p1->c-language);
}
     printf("请输入体育成绩(0-100):");
     scanf("%f",&p1->PE);
     while(p1->PE<0||p1->PE>100)
{
     getchar();
     printf("输入错误,请重新输入体育成绩");
     scanf("%f",&p1->PE);
}
     p1=head;
     p0=stu;
     if (head==NULL)
{
     head=p0;p0->next=NULL;       /*当原来链表为空时,从首节点开始存放资料,链表不能为空*/
}
     else
{
     if(p1->next==NULL)
{
     p1->next=p0;
     p0->next=NULL;       /*将它与新开单元相连接*/
}
     else
{
     while(p1->next!=NULL)
{
     p2=p1;p1=p1->next;
}
     p1->next=p0;
     p0->next=NULL;       /*还没找到末尾,继续找*/
}
}
     n=n+1;
     p1=head;
     p0=stu;   
     for(i=1;i<n;i++)
{
     for(j=i+1;j<=n;j++)
            
{
     max=p1;
     p1=p1->next;
     if(max->number>p1->number)
{
     k=max->number;
     max->number=p1->nmber;
     p1->number=k;      /*交换前后结点中的学号,使得学号大者移到后面的结点中*/
     strcpy(t,max->name);
     strcpy(max->name,p1->name);   /*交换前后结点中的姓名,使之与学号相匹配*/
     strcpy(p1->name,t)
     fen=max->mathmatic;
     p1->mathmatic=fen;
     fen=max->mathmatic=p1->mathmatic;
     p1->mathmatic=fen;
     fen=max->english;
     max->english=p1->english;
     p1->english=fen;
}
}
     max=head;p1=head;         /*重新使max,p指向链表头*/
}
     p2->next=NULL;
     printf("现在的学生个数为:%d个!\n",n);
     return(head);
}  
     score *search(score *head)
{
     int number;
     score *p1,*p2;
     printf("输入要查询的学生的学号:");
     scanf("%d",&number);
     while(number!=0)
{
     if(head==NULL)
{
     printf("\n没有任何学生资料!\n");
     return(head);
}
     printf("------------------------\n");
     printf("|学号\t|/姓名\t|数学\t|英语\t|计算机\t|c语言\t|体育\t|");
     printf("------------------------\n");
     p1=head;
     while(number!=p1->number&&p1->next!=NULL)
{
     p2=p1;
     p1=p1->next;
}
     if(number==p1->number)
{
     printf("|%d\t|%s\t|%.lf\t|%.lf\t|%.lf\t|%.lf\t|%.lf\t|\n",p->number,p->name,p->mathmatic,p->english,p->computer,
     p->c-language,p->PE);
     printf("---------------------\n");
}
     else
     printf("%d不存在此学生!\n",number);
     printf("输入要查询的学生学号,");
     }
     printf("退出!\n");
     return(head);
}
     score *dele(score *head)
     {
     score *p1,*p2;
     int number;
     printf("输入要删除的学生的学号:");
     scanf("%d",&nember);
     getchar();
     while(number!=0)       /*输入学号为0 时退出*/
{
     if(head==NULL)
     {
     printf("\n没有任何学生资料!\n");
     return(head);
}  
     p1=head;
     while(number!=p1->number&&p1->next!=NULL)    /*p1指向的不是要找的首节点,并且后面还有结点*/
{
     p2=p1;p1=p1->next;                           /*p1后移一个结点*/
}
     if(number==p1->number)                        /*找到结点*/
{
     if(p1==head)
     head=p1->next;                                /*若p1指向的是首节点,把第二个结点的地址赋值给head*/
     else
     p2->next=p1->next;                            /*把下一个结点赋给前一个结点*/
     printf("删除:%d\n",number);
     n=n-1;
     }
     else
     printf("%d不存在此学生!\n",number);
     printf("输入要删除学生的学号:");
     scanf("%d",&number);
     getchar();
     }
}
}
      

              
   
      
搜索更多相关主题的帖子: include 成绩查询 系统 
2012-09-06 00:41
快速回复:自己写的《成绩查询系统》,不知道错在哪了,菜鸟,包涵,
数据加载中...
 
   



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

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