【标题】学生成绩管理的设计与实现

【开发语言】C语言

【概要设计】使用结构体存储学生的学号、姓名和成绩信息,实现对学生成绩类的基本操作:增加、删除、查询、排序

【测试数据】按提示输入5组正确的正确的数据和5组有问题的数据,查看程序能否运行正确

【测试结果】基本功能运行正确,异常输入无法处理(关于性能对比测试,查看C++版:http://www.cnblogs.com/forerve/p/3908716.html

【详细设计】

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

 /*学生结构体*/
 struct student{
     ];
     ];
     ];
     double sum ;
 };

 /*链表节点*/
 typedef struct node{
     struct student st;
     struct node *Next;
 }Node;

 int Add(Node *Head);/*增加学生*/
 void Print(Node *Head);/*打印学生信息*/
 int Find(Node *Head);/*查询学生*/
 int Del(Node *Head);/*删除学生*/
 void sort_sum(Node *Head);/*按总成绩排序*/
 void sort_no(Node *Head);/*按学号排序*/
 void main_remid();/*主要提示信息*/
 void score_remind();/*成绩提示信息*/

 int main()
 {
     Node* Head = (struct node *)malloc(sizeof (Node));
     Head->Next = NULL;
     char op = ' ';
     main_remid();
     while(op != 'q')
     {
         scanf("%c", &op);
         switch(op)
         {
             ':
                 sort_no(Head);
                 break;
             ':
                 Add(Head);
                 break;
             ':
                 Find(Head);
                 break;
             ':
                 Del(Head);
                 break;
             ':
                 sort_sum(Head);
                 break;
             ':
                 main_remid();
                 break;
             default:
                 printf("输入指令未知,请重新输入\n");
                 break;
         }
         printf("请继续选择您想要的操作:\n");
         fflush(stdin);
     }
     ;
 }

 /*增加学生*/
 int Add(Node *Head)
 {
     Node* p = (struct node*)malloc(sizeof (Node));
     p->st.sum = 0.0;
     printf("请输入学生的学号\n");
     scanf("%s", p->st.no);
     printf("请输入学生的姓名\n");
     scanf("%s", p->st.name);
     printf("请输入学生的英语成绩\n");
     scanf(]);
     p->st.sum += p->st.couse[];
     printf("请输入学生的数学成绩\n");
     scanf(]);
     p->st.sum += p->st.couse[];
     printf("请输入学生的语文成绩\n");
     scanf(]);
     p->st.sum += p->st.couse[];
     printf("请输入学生的C语言成绩\n");
     scanf(]);
     fflush(stdin);
     p->st.sum += p->st.couse[];
     if(Head->Next == NULL)
     {
         p->Next = NULL;
         Head ->Next = p;
     }
     else
     {
         p->Next = Head ->Next;
         Head->Next = p;
     }
     ;
 }

 /*按总成绩排序*/
 void sort_sum(Node *Head)
 {
     Node *p = Head;
     Node *temp = (struct node*)malloc(sizeof (Node));
     Node *first = (struct node*)malloc(sizeof (Node));
     memcpy(first, p->Next ,sizeof (Node));
     temp->Next = first;
     first->Next = NULL;
     p = p->Next;
     while(p->Next != NULL)
     {
         Node *t = temp;
         while(t->Next!=NULL && p->Next->st.sum < t->Next->st.sum)
             t = t->Next;
         Node *q = (struct node*)malloc(sizeof (Node));
         memcpy(q, p->Next, sizeof(Node));
         q->Next = t->Next;
         t->Next = q;
         p = p->Next;
     }
     Print(temp);
     p = temp;
     Node *q = temp->Next;
     while(q->Next != NULL)
     {
         free(p);
         p = q;
         q = q->Next;
     }
     free(p);
     free(q);
 }

 /*按学号排序*/
 void sort_no(Node *Head)
 {
     Node *p = Head;
     Node *temp = (struct node*)malloc(sizeof (Node));
     Node *first = (struct node*)malloc(sizeof (Node));
     memcpy(first, p->Next ,sizeof (Node));
     temp->Next = first;
     first->Next = NULL;
     p = p->Next;
     while(p->Next != NULL)
     {
         Node *t = temp;
         while(t->Next!=NULL && atoi(p->Next->st.no)>atoi(t->Next->st.no))
             t = t->Next;
         Node *q = (struct node*)malloc(sizeof (Node));
         memcpy(q, p->Next, sizeof(Node));
         q->Next = t->Next;
         t->Next = q;

         p = p->Next;
     }
     Print(temp);
     p = temp;
     Node *q = temp->Next;
     while(q->Next != NULL)
     {
         free(p);
         p = q;
         q = q->Next;
     }
     free(p);
     free(q);
 }

 /*void sort_sum1(Node *Head)
 {
     Node *temp;
     Node *p = Head;
     temp->Next2 = p->Next;

     p = p->Next;
     p->Next2 = NULL;
     while(p->Next != NULL)
     {
         Node *t = temp;
         while(t->Next2!=NULL && p->Next->st.sum<t->Next2->st.sum)
             t = t->Next2;
         p->Next->Next2 = t->Next2;
         t->Next2 = p->Next;    

         p = p->Next;
     }
     Print(temp);

 }*/

 /*打印学生信息*/
 void Print(Node *Head)
 {
     Node* p = Head;
     score_remind();
     while(p->Next != NULL)
     {
         printf("\t%s", p->Next->st.no);
         printf("\t%s", p->Next->st.name);
         printf(]);
         printf(]);
         printf(]);
         printf(]);
         printf("\t%.1lf\n", p->Next->st.sum);
         p = p->Next;
     }
     p = NULL;
 }

 /*查询学生*/
 int Find(Node *Head)
 {
     Node* p = Head;
     printf("请输入要查找学生的学号:\n");
     ];
     scanf("%s", no);
     while(p->Next != NULL)
     {
         if(!strcmp(no, p->Next->st.no))
         {
             score_remind();
             printf("\t%s", p->Next->st.no);
             printf("\t%s", p->Next->st.name);
             printf(]);
             printf(]);
             printf(]);
             printf(]);
             printf("\t%.1lf\n", p->Next->st.sum);
             p = NULL;
             ;
         }
         p = p->Next;
     }
     printf("查找失败,不存在次学号\n");
     p = NULL;
     ;
 }

 /*删除学生*/
 int Del(Node *Head)
 {
     Node* p = Head;
     printf("请输入要删除学生的学号:\n");
     ];
     scanf("%s", no);
     while(p->Next != NULL)
     {
         if(!strcmp(no, p->Next->st.no))
         {
             Node *q = p->Next;
             p->Next = p->Next->Next;
             printf("%s  %s删除成功\n",q->st.no, q->st.name);
             free(q);
             q = NULL;
             ;
         }
         p = p->Next;
     }
     printf("不存在此学号\n");
 }

 /*主要提示信息*/
 void main_remid()
 {
     printf("\t\t\t学生成绩类\n");
     printf("\t\t1.查询所有学生的成绩信息\n");
     printf("\t\t2.增加学生\n");
     printf("\t\t3.查找学生\n");
     printf("\t\t4.删除学生\n");
     printf("\t\t5.查看总分排名\n");
     printf("\t\t6.查看此提示\n");
     printf("\t\tq.退出系统\n\n");
 }

 /*成绩提示信息*/
 void score_remind()
 {
     printf("\t\t\t 学生成绩信息\n");
     printf("\t学号\t姓名\t数学\t英语\t语文\tC语言\t总成绩\n");
 }

学生成绩管理C语言版的更多相关文章

  1. 学生成绩管理C++版

    [标题]学生成绩管理的设计与实现 [开发语言]C++ [主要技术]STL [概要设计]类名:student 类成员:No.Name.Math.Eng.Chn.Cpro.Sum 成员函数:getname ...

  2. C语言文件实现学生成绩管理

    C语言实现学生成绩管理 项目简介 用C语言的链表及文件操作实现学生成绩的管理,实现主要的添加.修改.删除.查询的主要功能,并在程序关闭时将数据存储在二进制的文件中并加密.下一次打开程序,先解密二进制文 ...

  3. JAVA课程设计 学生成绩管理

    学生成绩管理 可实现功能: 添加学生功能:姓名.学号.性别.出生年月日.(学号自动生成且唯一) 添加学生成绩功能:每个人都有数学.Java与体育四门课,可分课程输入成绩. 根据学生学号查找学生成绩功能 ...

  4. C语言学生成绩管理系统(简易版)

    #include<stdio.h> #include<stdlib.h> #include<string.h> int readstudents(struct st ...

  5. 开学考试学生成绩管理Java

    首先student类 package xuexi; public class Student { private String stunumber; private String name; priv ...

  6. 学生成绩管理系统-JAVA语言测试

     首先右键新建一个工程project 选择Java Project,单击next下一步 project命名为“学生成绩管理系统”,点击finish继续 右键src文件夹新建Package包,取名为te ...

  7. JAVA基础代码分享--学生成绩管理

    问题描述: 从键盘读入学生成绩,找出最高分,并输出学生成绩等级. 成绩>=最高分-10  等级为’A’   成绩>=最高分-20  等级为’B’ 成绩>=最高分-30  等级为’C’ ...

  8. JAVA课程设计个人博客 学生成绩管理 201521123001 张陈东芳

    1. 团队课程设计博客链接 http://www.cnblogs.com/kawajiang/p/7062407.html 2.个人负责模块或任务说明 我主要负责实现学生信息的添加功能.学生成绩的录入 ...

  9. 简易学生成绩管理管理系统(java描述)

    没正式学过java,但是系统学过C++后,初略的看了下java的基本语法,于是我就尝试着用java来写个简单的学生管理系统,功能不齐全,以后有空再补充吧. 写的时候定义了不同的包名字,如jeaven1 ...

随机推荐

  1. spring security 3.x 多页面登录配置入门教程

    最近在最shiro的多入口登录,搞了好久,就把spring security拿出来再炒一下,这是我以前在csdn写过的一篇博客. spring security 是一个权限控制的框架.可以很方便地实现 ...

  2. 20155323 2016-2017-2 《Java程序设计》第5周学习总结

    20155323 2016-2017-2 <Java程序设计>第5周学习总结 教材学习内容总结 异常处理 提供两种异常处理机制:捕获异常和声明抛弃异常. 捕获异常:在Java程序运行过程中 ...

  3. 测试开发Python培训:抓取新浪微博评论提取目标数据-技术篇

    测试开发Python培训:抓取新浪微博评论提取目标数据-技术篇   在前面我分享了几个新浪微博的自动化脚本的实现,下面我们继续实现新的需求,功能需求如下: 1,登陆微博 2,抓取评论页内容3,用正则表 ...

  4. 收集下shell使用笔记

    让进程转入后台: Ctrl + z 将进程转到前台: fg 产生随机的十六进制数,其中n是字符数: openssl rand -hex n 截取前5个字符: ${variable::} 一次创建多个目 ...

  5. 08 Noise and Error

    噪声:误标.对同一数据点的标注不一致.数据点信息不准确... 噪声是针对整个输入空间的. 存在噪声的情况下,VC bound依旧有用: 存在噪声,就是f--->p(y|x),f是p的特殊情况:如 ...

  6. java 基础知识二 基本类型与运算符

    java  基础知识二 基本类型与运算符 1.标识符 定义:为类.方法.变量起的名称 由大小写字母.数字.下划线(_)和美元符号($)组成,同时不能以数字开头 2.关键字 java语言保留特殊含义或者 ...

  7. 第一章 自定义MVC框架

    第一章  自定义MVC框架1.1 MVC模式设计    组成:Model:模型,用于数据和业务的处理          View :视图,用于数据的显示          Controller:控制器 ...

  8. Unity CommandInvokationFailure: Failed to re-package resources. 解决方案

    在导入谷歌的SDK的时候,打包出来报错CommandInvokationFailure: Failed to re-package resources. 把Android SDK更新一下就轻松搞定了, ...

  9. Python 基础三 文件 函数

    今天回顾一下之前学的文件操作相关知识点,对于文件的操作,主要有一下几部分构成: 一.文件的基础知识 1.文件操作的基本流程 文件操作其实可以分成三大部分: 1.打开文件,获取文件句柄并赋予一个变量 2 ...

  10. 由CODEVS笨小猴1053引发的一些思考

    #include<cstdio> #include<cstring> ]; ]; int check(int n) { ||n==) ; ;m*m<=n;++m) ) ; ...