C语言学生信息管理系统

本文实例为大家分享了C语言学生信息管理系统的具体代码,供大家参考,具体内容如下

列表内容

系统以菜单方式工作
学生信息录入功能(学生信息用文件保存)—输入
学生信息浏览功能——输出
查询、排序功能——算法
1、按学号查询
2、按姓名查询
学生信息的删除与修改
界面简单明了;
有一定的容错能力,比如输入的成绩不在0~100之间,就提示不合法,要求重新
输入;
用链表的方式实现。

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

typedef struct Student
{
  char name[100]; //姓名
  char num[100]; //学号
  char sex;//性别 (w代表女生m代表男生)
  int age;//年龄
  int score;//成绩
}stu;
typedef struct LNode
{
  stu data;
  struct LNode *next;
}LinkList; 

char nam[100];//名字
char nu[100];//学号
char s;//性别
int ag;//年龄
int sc;//成绩 

void welocome()//登陆界面
{
  system("color b1");
  printf("````````````````````````````````````````````````````````````````````````````````");
  printf("\n");
  printf("\n");
  printf("\n");
  printf(" *********************** 欢迎登录学生信息管理平台 ************************* \n");
  printf("\n");
  printf("\n");
  printf("\n");
  printf("````````````````````````````````````````````````````````````````````````````````");
} 

void menu()//功能菜单
{
  system("color e3");
  printf("  |________________________________________________|\n");
  printf("  |                        |\n");
  printf("  |        学生信息管理系统        |\n");
  printf("  |                        |\n");
  printf("  |        0、退出系统           |\n");
  printf("  |        1、增加学生信息         |\n");
  printf("  |        2、删除学生信息         |\n");
  printf("  |        3、修改学生信息         |\n");
  printf("  |        4、查找学生的信息        |\n");
  printf("  |        5、按照学生成绩排序       |\n");
  printf("  |        6、浏览全部学生信息       |\n");
  printf("  |        7、保存学生信息到文件      |\n");
  printf("  |                        |\n");
  printf("  |________________________________________________|\n");
  return ;
} 

void InitList( LinkList *&L)//初始化链表
{
  L=(LinkList *)malloc(sizeof(LinkList));
  L->next=NULL;
} 

void ListInsert(LinkList *&L,LinkList *p)//插入新的节点
{
  LinkList *q=NULL;
  q=L;
  p->next=q->next;
  q->next=p;
} 

void addstu(LinkList *&L)//增加新的学生
{
  system("color f2");
  printf("请输入学生的信息:\n");
  printf("学号:");
  scanf("%s",nu);
  LinkList *q=L->next;
  while(q!=NULL )
  {
    if(strcmp(q->data.num,nu)==0)//判断是否存在
    {
      printf("该生已存在\n");
      break;
    }
    q=q->next;
  }
  if(q==NULL)
  {
    LinkList *p;
    InitList(p);
    strcpy(p->data.num,nu);
    printf("姓名:") ;
    scanf("%s",nam) ;
    strcpy(p->data.name,nam);
    printf("性别:(w为男 m为女)");
    scanf(" %c",&s);
    p->data.sex=s;
    printf("年龄:");
    scanf("%d",&ag);
    p->data.age=ag;
    printf("总成绩:");
    scanf("%d",&sc);
    while(sc>100||sc<0){
      printf("输入有误,请重新输入\n");
      scanf("%d",&sc);
    }
    p->data.score=sc;
    ListInsert(L,p); 

  }
} 

void deletestu(LinkList *L)//删除学生
{
  system("color f4");
  printf("请输入您要删除的学生的学号:");
  scanf("%s",nu);
  //判断
  LinkList *p,*pre;
  if(L->next==NULL)
  {
    printf("还没有学生信息,请增加学生信息\n");
    return;
  }
  pre=L;
  p=pre->next;
  int judge=0;
  while(p)
  {
     if(strcmp(p->data.num,nu)==0)
     {
         judge=1;
         pre->next =p->next;
         free(p);
         printf("删除学生成功\n");
         break;
     }
     pre=p;
     p=p->next;
  }
  if(judge==0)
    printf("该生不存在\n");
} 

void changestu(LinkList *L)//改变学生信息
{
  int judge=1;
  system("color e4");
  printf("请输入您要修改学生的学号:\n");
  scanf("%s",nu);
  LinkList *q=L->next;
  while(q!=NULL )
  {
    if(strcmp(q->data.num,nu)==0)
    {
      judge=1;
      printf("请输入您要修改的信息选项:1.姓名 2. 总成绩 3.年龄  \n");
      int n;
      scanf("%d",&n);
      switch(n)
      {
      case 1:
        printf("请输入您要修改的名字:");
        scanf("%s",nam);
        printf("修改的名字为:%s\n",nam);
        strcpy(q->data.name,nam);
        printf("修改名字成功!\n");
        break;
      case 2:
        printf("请输入您要修改的总成绩");
        scanf("%d",&sc);
        printf("修改的总成绩为:%d\n",sc);
        q->data.score=sc;
        printf("修改总成绩成功!\n"); 

        break;
      case 3:
        printf("请输入您要修改的年龄:");
        scanf("%d",&ag);
        printf("修改的年龄为:%d\n",ag);
        q->data.age=ag;
        printf("修改年龄成功!\n");
        break;
      default :
        printf("请输入正确的选项\n");
        break;
      }
    }
    q=q->next;
  }
  if(judge==0)
  {
   printf("该生不存在\n");
  }
} 

void findstu(LinkList *L)//按学号或者姓名查找学生并输出该生信息
{
  int flag;
  system("color b1");
  printf("1.按学号查询:\n");
  printf("2.按姓名查询:\n");
  printf("请输入查询方式:");
  scanf("%d",&flag);
  if(flag==1){
    printf("请输入该生学号:");
    scanf("%s",nu);
    //判断
    LinkList *q=L->next;
    while(q!=NULL )
    {
      if(strcmp(q->data.num,nu)==0)
      {
        printf("姓名:%s\n",q->data.name);
        printf("学号:%s\n",q->data.num);
        printf("性别:%c\n",q->data.sex);
        printf("年龄:%d\n",q->data.age);
        printf("总成绩:%d\n",q->data.score);
        break;
      }
       q=q->next;
    }
    if(q==NULL)
      printf("该生不存在\n");
  }else{
    printf("请输入该生姓名:");
    scanf("%s",nam);
    LinkList *q=L->next;
    while(q!=NULL )
    {
      if(strcmp(q->data.name,nam)==0)
      {
        printf("姓名:%s\n",q->data.name);
        printf("学号:%s\n",q->data.num);
        printf("性别:%c\n",q->data.sex);
        printf("年龄:%d\n",q->data.age);
        printf("总成绩:%d\n",q->data.score);
        break;
      }
       q=q->next;
    }
    if(q==NULL)
      printf("该生不存在\n");
  }
} 

void display(LinkList *&L)//浏览全部学生信息
{
  LinkList *q=L->next;
  if(q==NULL)
  {
    printf("还没有学生信息,请增加学生信息\n");
    return;
  }
  while(q)
  {
    system("color c0");
    printf(" 学号:%s 名字:%s 年龄:%d 性别:%c 总成绩:%d \n",q->data.num,q->data.name,q->data.age,q->data.sex,
   q->data.score);
    q=q->next;
  }
} 

void paixu(LinkList *L)//按成绩排序排序 并输出排序后的结果
{
  system("color f9");
  LinkList *q,*p,*r=L->next;
  //判断
  if(r==NULL)
  {
    printf("还没有学生信息,请增加学生信息\n");
    return;
  }
  while(r) //两层循环完成排序
  {
     p=r;
     q=r->next;
     LinkList *tmp;//用于排序时暂存节点
     InitList(tmp);
     while(q)
     {
       if(q->data.score > p->data.score)
       {
        /*先复制q结点信息到tmp*/
        strcpy(tmp->data.num,q->data.num);
        strcpy(tmp->data.name,q->data.name);
        tmp->data.sex=q->data.sex;
        tmp->data.age=q->data.age;
        tmp->data.score=q->data.score;
        /*再复制p结点信息到q*/
        strcpy(q->data.num,p->data.num);
        strcpy(q->data.name,p->data.name);
        q->data.sex=p->data.sex;
        q->data.age=p->data.age;
        q->data.score=p->data.score;
        /*最后复制exchange结点信息到p*/
        strcpy(p->data.num,tmp->data.num);
        strcpy(p->data.name,tmp->data.name);
        p->data.sex=tmp->data.sex;
        p->data.age=tmp->data.age;
        p->data.score=tmp->data.score;
       }
       q=q->next;
     }
     r=r->next;
  } 

  printf("排序后的学生信息是:\n");
  display(L);
} 

void saveStuDentFile(LinkList * &L)//保存学生信息到文件
{
  FILE *fp;
  LinkList *p=L->next;
  if((fp=fopen("student.txt","w"))==NULL)// 以可写的方式打开当前目录下的.txt
  {
    printf("不能打开此文件,请按任意键退出\n");
    exit(1);
  }
  while(p)
  {
    fprintf(fp,"%s %s %c %d %d \n",p->data.num,p->data.name,p->data.sex,p->data.age,p->data.score);
    p=p->next;
    printf("保存成功\n");
  }
    fclose(fp);
} 

void readStuDentput (LinkList *&L) //运行前把文件内容读取到电脑内存
{
  FILE *fp;
  fp=fopen("student.txt","rb"); //以只读方式打开当前目录下的.txt
  if(fp==NULL)
  {
    printf("不存在打开文件\n");
    exit(0);          //终止程序
  }
  int i=0;
  while(!feof(fp))
  {
    char nu[100];//学号
    char nam[100];//名字
    char s;//性别
    int ag;//年龄
    int sc;//成绩
    fscanf(fp," %s %s %c %d %d",nu,nam,&s,&ag,&sc);
    i++;
  }
  fclose(fp);
  FILE *FP;
  FP=fopen("student.txt","rb"); //以只读方式打开当前目录下的.txt
  if(FP==NULL)
  {
    printf("无法打开文件\n");
    exit(0); //终止程序
  }
  int b=i-1;
  int j=1;
    while(!feof(FP))
    {
      fscanf(FP,"%s %s %c %d %d",nu,nam,&s,&ag,&sc);
      LinkList *n=(LinkList *)malloc(sizeof(LinkList));
      strcpy(n->data.num,nu);//把后者的内容拷贝到前者中
      strcpy(n->data.name,nam);//把后者的内容拷贝到前者中
      n->data.sex=s;
      n->data.age=ag;
      n->data.score=sc;
      ListInsert(L,n);//插入新的节点
      n=n->next;
      if(j==b)
        break;
      j++;
    }
  fclose(FP);  //关闭文件
} 

int main()
{
  system("cls");//清屏
  welocome();//登陆界面
  Sleep(3000);//延缓3秒
  LinkList *L;
  InitList(L);
  readStuDentput (L);//运行前把文件内容读取到电脑
  int a;
  int choose;
  while(1)
  {
    printf("请输入您要选择的功能键:\n");
    menu();//功能菜单
    scanf("%d",&choose);
    switch(choose)
    {
    case 0://退出
      printf("谢谢使用!欢迎下次光临");
      exit(0);
    case 1://增加学生信息
      addstu(L);//增加新的学生
      break;
    case 2://删除所有学生信息
      deletestu(L);//删除学生
      break;
    case 3://改变个学生的信息
      changestu(L);//改变学生信息
      break;
    case 4://查找某个学生的信息
      findstu(L);//按学号查找学生并输出该生信息
      break; 

    case 5:// 对学生成绩进行排序
      paixu(L);
      break;
    case 6://输出所有学生的信息
      display(L);
      break;
    case 7://保存学生信息到文件
      saveStuDentFile(L);
      break;
    default:
      printf("请输入正确的选择\n");
      break;
    }
  }
} 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • 学生信息管理系统C语言版

    C语言学生信息管理系统包括以下功能: 1.学生信息的整体注册 2.学生信息的修改 3.学生成绩信息的录入 4.学生信息的添加 5.恢复误删的学生信息 6.学生信息的删除 7.密码修改保存函数 8.学生信息的查询 9.密码修改函数 10.学生信息管理系统的菜单函数 #include "stdio.h" #include "malloc.h" #include "string.h" #include "stdlib.h" #inc

  • C语言数据结构之学生信息管理系统课程设计

    本文实例为大家分享了学生信息管理系统设计的具体代码,供大家参考,具体内容如下 建立一个动态链表,链表中每一结点包括:学号.姓名.性别.年龄.成绩.程序能实现以下功能: 建立链表      显示链表      查找链表中是否存在某个元素,并显示这个元素的所有信息,若没有这个元素则显示"无此记录!"的信息.      删除链表中指定学号的结点.      在链表中指定的位置插入一个新结点(学号不能和其他结点重复). 要求:程序运行中,先显示实现以上功能所构成的菜单,然后根据选项调用相应程序

  • C语言实现学生信息管理系统(单链表)

    本文实例为大家分享了C语言实现学生信息管理系统的具体代码,供大家参考,具体内容如下 /*copyright(c)2016.烟台大学计算机学院 * All rights reserved, * 文件名称:text.Cpp * 作者:吴敬超 * 完成日期:2016年7月1日 * 版本号:codeblock * * 问题描述: 学生信息管理系统 * 输入描述: * 程序输出: 输出结果 */ #include <stdio.h> #include <stdlib.h> #include

  • C语言职工信息管理系统源码

    本文实例为大家分享了C语言职工信息管理系统的具体代码,供大家参考,具体内容如下 #include <stdio.h> #include <stdlib.h> #include <string.h> #include <conio.h> struct worker { char ID[20];//工号 char name[20];//姓名 char sex[5];//性别 char born[20];//生日 char edu[20];//学历 char po

  • C语言单链表版学生信息管理系统

    本文实例为大家分享了C语言学生信息管理系统的具体代码,供大家参考,具体内容如下 代码: //以单链表作为存储结构,设计和实现课程成绩管理的完整程序. //程序包括如下功能. //1.建立学生成绩表,包含学生的学号.姓名和成绩. //2.可以显示所有学生成绩. //3.可以计算学生的总数. //4.可以按学号和序号查找学生. //5.可以在指定位置插入学生成绩数据. //6.可以删除指定位置的学生数据. //7.可以把学生成绩按从高到低的顺序排序. //作者: yinlinqvan //操作系统:

  • c语言实现的货物管理系统实例代码(增加删除 查找货物信息等功能)

    复制代码 代码如下: #include <stdio.h>#include <stdlib.h>#include <string.h>#include <conio.h>        /*屏幕操作函数库*/ /*主管权限数据格式化*/#define HEADER1_zg "-----------------------------货物管理系统(主管)--------------------------------\n"#define H

  • C语言实现歌曲信息管理系统

    本文实例为大家分享了C语言实现歌曲信息管理系统的具体代码,供大家参考,具体内容如下 系统功能:该系统以菜单方式工作,歌曲信息包括:歌名.演唱者.作词.作曲.所属专辑.出版时间.出版公司.试设计一歌厅歌曲管理系统,使之能提供以下功能:歌曲信息录入.修改.插入.删除功能:歌曲排序浏览功能:按歌名查询.按演唱者查询等功能. 完整的实现代码如下: #include "stdio.h" #include "stdlib.h" #include "string.h&q

  • C语言学生信息管理系统小项目

    本文为大家分享了C语言学生信息管理系统小项目,供大家参考,具体内容如下 /* 运行环境:我是在linux里面用gcc编译的,在windows里应该也能运行,用的一些文件库函数都是c标准库,没有用linux的系统调用(纠正一下:system("clear")这个系统调用是linux的,windows里面用system("cls") ) (1)问题描述 学生信息包括:学号,姓名,年龄,性别,出生年月,地址,电话,E-mail等.试设计一学生信息管理系统,使之能提供以下功

  • C语言学生信息管理系统设计与实现

    本文实例为大家分享了C语言学生信息管理系统的具体代码,供大家参考,具体内容如下 #include"stdio.h" //标准的输入输出函数文件头部说明 #include"math.h" // 数学函数头部说明 #include"string.h" #include"stdlib.h" //通过该函数头部里的函数,改变控制台的背景和颜色 #include"windows.h" //头文件声明,下文用到了改变控

  • C语言数组实现学生信息管理系统设计

    概述 单纯只用多个数组管理学生成绩信息,不使用结构体,该程序最主要的难点是依据学号或总成绩对学生信息进行排序,借助了临时数组来标记排好序的下标. 运行结果如下: 输入数据: 打印数据: 根据学号对信息进行排序: 根据总成绩对信息进行排序: 根据学号删除某一信息: 代码如下: #include <stdio.h> #include <stdlib.h> //exit函数头文件 #include <string.h> //字符串相关操作头文件 #define MAX_STU

随机推荐