广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >使用C语言实现学生成绩管理系统
  • 617
分享到

使用C语言实现学生成绩管理系统

2024-04-02 19:04:59 617人浏览 泡泡鱼
摘要

最近正在学习C语言,搞了一个学生成绩管理系统的小程序,代码粗陋,大佬勿喷。 先上图: 整个程序采用链表来管理学生成绩,保存学生成绩用的是 文件处理函数,使用 fopen(FileP

最近正在学习C语言,搞了一个学生成绩管理系统的小程序,代码粗陋,大佬勿喷。

先上图:

主菜单

整个程序采用链表来管理学生成绩,保存学生成绩用的是 文件处理函数,使用 fopen(FilePath, “wb”) 将学生信息在内存中的数据直接写入文件,相应的打开程序后读取时使用 fopen(FilePath, “rb”) 将数据直接再次还原到内存中去。

选项6 是手动保存链表数据及配置数据。
选项7 配置每次修改链表中的数据是否需要自动保存。

选项1 进入后,直接按照提示输入 学生的各个信息,一行一个


选项3 修改学生信息,进入后选择以什么方式查找要修改的学生,然后输入学生的学号或姓名,找到之后(因为可能存在重名的同学,所以这里做了序号索引),输入结果索引,然后根据提示将该学生的信息重新输入一遍,达到修改的效果。

选项4 查询,功能如上图所示

选项5 排序,根据提示输入条件,排序会导致链表数据改变,所以回到主菜单后会自动保存数据到文件

选项8 投票系统,输入链表中存在的人名,对应下方投票结果会实时变动,并排序,最高票数的人颜色高亮。


选项9 输入后右侧出现提示“导出成功”,则在相应目录下会出现student_export.txt文件,里面包含有链表中所有学生信息,这里采用的是 fprintf 函数输出到文件。

链表排序时,数据交换使用了kernel32.dll 中的内存数据拷贝 MoveMemory 函数,只需要将除链表中的pNext 以外的数据进行拷贝交换即可。

下面上代码:


// 学生管理系统.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"
#include "string.h"
#include "coNIO.h"
#include "windows.h"
#include "stdlib.h"

#define LIST_TITLE "学号 姓名 性别 语文 数学 英语\n"
#define LIST_TITLE_1 "学号 姓名 性别 语文 数学 英语 均分\n"
#define FILE_DATABASE "C:\\student_database.dat"
#define FILE_EXPORT "C:\\student_export.txt"
//颜色
enum
{
 BLACK,
 BLUE,
 GREEN,
 CYAN,
 RED,
 MAGENTA,
 BROWN,
 LIGHTGRAY,
 DARKGRAY,
 LIGHTBLUE,
 LIGHTGREEN,
 LIGHTCYAN,
 LIGHTRED,
 LIGHTMAGENTA,
 YELLOW,
 WHITE
};
//功能索引
enum
{
 Func_Add = 1,//添加学生信息
 Func_Delete,//删除
 Func_Modify,//修改
 Func_Search,//搜索
 Func_Sort,//排序
 Func_Save,//保存
 Func_AutoSave,//自动保存
 Func_Vote,//投票系统
 Func_Export,//导出学生信息
 Func_ExitSystem//退出系统
};
struct Student
{
 int num;//学号
 char name[20];//姓名
 char sex[8];//性别
 float score[3];//三门课程成绩
 float averge;//平均分
 int count;//投票计数
 Student* pNext;

};
Student* G_pStuHead;//链表头
bool G_autoStore = false;//自动保存




void setFontColor(int ForGC)
{
 Word wColor;
 HANDLE hOutput = GetStdHandle(STD_OUTPUT_HANDLE);
 CONSOLE_SCREEN_BUFFER_INFO csbi;
 
 if(GetConsoleScreenBufferInfo(hOutput, &csbi))
 {
  //设置字体颜色
  wColor = (csbi.wAttributes & 0xF0) + (ForgC & 0x0F);
  SetConsoleTextAttribute(hOutput, wColor);
 }
}



void Gotoxy(int x, int y)
{
    // 更新光标位置 
    COORD pos;
 
    HANDLE hOutput = GetStdHandle(STD_OUTPUT_HANDLE);
    pos.X = x;
    pos.Y = y;
    SetConsoleCursorPosition(hOutput, pos);
 // 隐藏光标 
//     CONSOLE_CURSOR_INFO cursor;
//     cursor.bVisible = FALSE;
//     cursor.dwSize = 1; //值介于1 ~ 100 之间 单元格底部为下划线 ~ 完全填充单元格
//     SetConsoleCursorInfo(hOutput, &cursor);
 
}



void printAutoStoreInfo()
{
 setFontColor(LIGHTGREEN);
 gotoxy(13, 10);
 printf("%s\n", G_autoStore ? "是" : "否");
 setFontColor(WHITE);
}



void showSystemTitle()
{
 setFontColor(LIGHTGREEN);
 printf("--------------------------------------------------------\n");
 printf("\t\t欢迎进入学生管理系统\n");
 printf("--------------------------------------------------------\n");
 setFontColor(WHITE);
}



void initScreen()
{
 system("CLS");
 showSystemTitle();
 printf("请输入数字序列号,选择您要执行的操作:\n");
 printf("1、添加学生信息\n");
 printf("2、删除学生信息\n");
 printf("3、修改学生信息\n");
 printf("4、查询学生信息\n");
 printf("5、排序\n");
 printf("6、保存(如打开自动保存,则无需手动执行)\n");
 printf("7、自动保存:");
 printAutoStoreInfo();
 printf("8、投票系统\n");
 printf("9、导出学生信息\n");
 setFontColor(LIGHTRED);
 printf("10、退出学生管理系统\n");
 setFontColor(WHITE);

}



void gotodelete(int x, int y, int length)
{
 int i;
    
 for (i = 0; i < length; i++)
 {
  gotoxy(x + i, y);
  printf(" ");
 }
}



void gotodelete(int x, int y)
{
 gotodelete(x, y, 1);
}



void voteSystem()
{
 bool hasFound;
 char name[20];
 int count, i, j;
 Student* pStu, *pTmp;
 Student** pStuArr;

 //初始化票数清零
 pStu = G_pStuHead->pNext;
 while(pStu != NULL)
 {
  pStu->count = 0;
  pStu = pStu->pNext;
 }

 count = 0;
 pStuArr = (Student**)malloc(4 * 100);//用于存放已经获得票数的同学指针
 gotoxy(0, 6);
 printf("投票结果如下:\n");
 gotoxy(0, 3);
 printf("请在下方输入你想投给的人的姓名(输入-1返回主菜单):\n");
 
 while (1)
 {
  gotodelete(0, 4, 20);//清空输入行
  gotoxy(0, 4);
  scanf("%s", name);
  
  if(strcmp(name, "-1") == 0)
  {
   break;
  }
  hasFound = false;
  pStu = G_pStuHead->pNext;
  //在系统中查找对应的人名
  while(pStu != NULL)
  {
   if(strcmp(pStu->name, name) == 0)
   {
    hasFound = true;
    break;
   }
   pStu = pStu->pNext;
  }
  if(! hasFound)
  {
   printf("查无此人!!!");
   Sleep(1000);
   gotodelete(0, 5, 20);
   continue;
  }
  //找到之后,这个人所对应的票数+1
  pStu->count++;
  for (i = 0; i < count; i++)
  {
   if(pStuArr[i] == pStu)
   {
    break;
   }
  }
  if(i == count)//说明未找到,则添加进候选人数组
  {
   pStuArr[count++] = pStu;
   if(count % 100 == 0)
   {
    pStuArr = (Student**)realloc(pStuArr, count + 100);
   }
  }
  //冒泡排序,票数
  for (i = 0; i < count - 1; i++)
  {
   for (j = i + 1; j < count; j++)
   {
    if(pStuArr[i]->count < pStuArr[j]->count)
    {
     pTmp = pStuArr[i];
     pStuArr[i] = pStuArr[j];
     pStuArr[j] = pTmp;
    }
   }
  }
  gotoxy(0, 7);//跳转到打印票数的那行
  //打印票数
  for (i = 0; i < count; i++)
  {
   if(i == 0)
   {
    setFontColor(LIGHTGREEN);
   }
   else
   {
    setFontColor(WHITE);
   }
   printf("%d %s\t%d\n", pStuArr[i]->num, pStuArr[i]->name, pStuArr[i]->count);
  }

 }
 free(pStuArr);
 
}



bool exportStudentInfo()
{
 Student* pStu;
 FILE* fp;

 pStu = G_pStuHead->pNext;

 if((fp = fopen(FILE_EXPORT, "w")) == NULL)
 {
  return false;
 }
 while (pStu != NULL)
 {
  fprintf(fp, "%d %s  %s %.2f %.2f %.2f %.2f\n", pStu->num, pStu->name, pStu->sex, 
       pStu->score[0], pStu->score[1], pStu->score[2], pStu->averge);
  pStu = pStu->pNext;
 }
 fclose(fp);
 return true;
}



bool saveStudentInfo()
{
 FILE *fp;
 Student *pStu;

 pStu = G_pStuHead;

 if((fp = fopen(FILE_DATABASE, "wb")) == NULL)
 {
  return false;
 }
 fwrite(&G_autoStore, sizeof(G_autoStore), 1, fp);
 while (pStu != NULL)
 {
  fwrite(pStu, sizeof(Student), 1, fp);
  pStu = pStu->pNext;
 }
 fclose(fp);
 return true;
}



bool loadStudentInfo()
{
 FILE *fp;
 int count;
 Student stu, *pStu, *pStuNew;

 count = 0;
 pStu = G_pStuHead;

 if((fp = fopen(FILE_DATABASE, "rb")) == NULL)
 {
  return false;
 }
 fread(&G_autoStore, sizeof(G_autoStore), 1, fp);//读取是否自动保存
 while(1)
 {
  fread(&stu, sizeof(Student), 1, fp);//读取文档中每个同学的数据
  if(feof(fp))//到文档尾则跳出
  {
   break;
  }
  if(count++ > 0)//这里 > 0 是因为保存的时候会把链表头保存进去,而链表头是没有有效数据的,所以要排除掉
  {
   pStuNew = (Student*)malloc(sizeof(Student));
   MoveMemory(pStuNew, &stu, sizeof(Student) - 4);//将结构体除指针外的所有数据拷贝进内存
   pStuNew->pNext = NULL;
   pStu->pNext = pStuNew;
   pStu = pStuNew;
  }
  if(stu.pNext == NULL)
  {
   break;
  }
 }
 fclose(fp);
 return true;
}



bool sortStudentInfo()
{
 int order1, order2;
 bool swapData;
 char yesOrNo;
 Student* pStu1, *pStu2, tmpStu;

 pStu1 = G_pStuHead->pNext;
 if(pStu1 == NULL)
 {
  printf("系统中无学生信息!\n");
  system("pause");
  return false;
 }
 printf("输入以下序号执行相应功能(输入其他序号返回主菜单):\n");
 printf("1、根据学号进行排序\n");
 printf("2、根据姓名排序\n");
 printf("3、根据语文成绩排序\n");
 printf("4、根据数学成绩排序\n");
 printf("5、根据英语成绩排序\n");
 printf("6、根据平均分成绩排序\n");

 scanf("%d", &order1);
 if(order1 >= 1 && order1 <= 6)
 {
  printf("请选择正序OR倒序排列?(输入其他序号返回主菜单)\n");
  printf("1、正序排列\n");
  printf("2、倒序排列\n");
  scanf("%d", &order2);
  if(order2 >= 1 && order2 <= 2)
  {
   //冒泡排序
   for ( ; pStu1->pNext != NULL; pStu1 = pStu1->pNext)
   {
    for (pStu2 = pStu1->pNext; pStu2 != NULL; pStu2 = pStu2->pNext)
    {
     swapData = false;//是否交换数据
     switch(order1)
     {
     case 1://根据学号排序
      {
       if(order2 == 1 ? (pStu1->num > pStu2->num) : (pStu1->num < pStu2->num))//三目运算符, 判断正序还是倒序
       {
        swapData = true;
       }
       break;
      }
     case 2://根据姓名排序
      {
       if(order2 == 1 ? (strcmp(pStu1->name, pStu2->name) > 0) : (strcmp(pStu1->name, pStu2->name) < 0))
       {
        swapData = true;
       }
       break;
      }
     case 3://根据语文排序
     case 4://根据数学排序
     case 5://根据英语排序
      {
       if(order2 == 1 ? (pStu1->score[order1 - 3] > pStu2->score[order1 - 3]) : (pStu1->score[order1 - 3] < pStu2->score[order1 - 3]))
       {
        swapData = true;
       }
       break;
      }
     case 6://根据均分排序
      {
       if(order2 == 1 ? (pStu1->averge > pStu2->averge) : (pStu1->averge < pStu2->averge))
       {
        swapData = true;
       }
       break;
      }
     }

     if(swapData)
     {
      //交换内存数据,只需要将除pNext指针外的结构体数据拷贝交换即可
      MoveMemory(&tmpStu, pStu1, sizeof(Student) - 4);
      MoveMemory(pStu1, pStu2, sizeof(Student) - 4);
      MoveMemory(pStu2, &tmpStu, sizeof(Student) - 4);
     }
    }
   }
   printf("排序完成,是否显示?Y/N\n");
   getchar();//过滤掉输入时的换行符
   scanf("%c", &yesOrNo);
   if(yesOrNo == 'Y' || yesOrNo == 'y')
   {
    pStu1 = G_pStuHead->pNext;
    setFontColor(LIGHTGREEN);
    printf(LIST_TITLE_1);//显示列表标题头
    setFontColor(WHITE);
    //打印排序后的各个学生信息
    while(pStu1 != NULL)
    {
     printf("%d %s  %s %.2f %.2f %.2f %.2f\n", pStu1->num, pStu1->name, pStu1->sex, 
       pStu1->score[0], pStu1->score[1], pStu1->score[2], pStu1->averge);
     pStu1 = pStu1->pNext;
    }
    system("pause");
   }
   return true;

  }
 }
 return false;
}



void searchStudentInfo()
{
 bool hasFound;
 int order, stuID, count, i, min, max;
 float score;
 char name[20];
 Student* pStu;
 Student** pStuArr;

 pStuArr = NULL;
 
 while (1)
 {
  system("CLS");
  showSystemTitle();

  if(pStuArr != NULL)//如果再次查询,这里需要判断,将上一轮查询的学生信息指针数组清空
  {
   free(pStuArr);
  }
  count = 0;
  stuID = 0;
  hasFound = false;
  pStu = G_pStuHead->pNext;
  pStuArr = (Student**)malloc(4 * 100);//初始化查询到后存放的学生信息指针数组

  printf("输入以下序号执行相应功能(输入其他序号返回主菜单):\n");
  printf("1、输入学号查询信息\n");
  printf("2、输入姓名查询信息\n");
  printf("3、输入语文成绩范围查询信息\n");
  printf("4、输入数学成绩范围查询信息\n");
  printf("5、输入英语成绩范围查询信息\n");
  printf("6、输入平均分范围查询信息\n");
  printf("7、列出所有学生信息\n");

  scanf("%d", &order);
  switch(order)
  {
  case 1://根据学号查询
   {
    printf("请输入要查询的学生学号:");
    scanf("%d", &stuID);
    while (pStu != NULL)
    {
     if(pStu->num == stuID)
     {
      hasFound = true;
      break;
     }
     pStu = pStu->pNext;
    }
    if(hasFound)//
    {
     setFontColor(LIGHTGREEN);
     printf(LIST_TITLE_1);
     setFontColor(WHITE);
     printf("%d %s  %s %.2f %.2f %.2f %.2f\n", pStu->num, pStu->name, pStu->sex, 
       pStu->score[0], pStu->score[1], pStu->score[2], pStu->averge);
    }
    
    break;
   }
  case 2://根据姓名查询
   {
    printf("请输入要查询的学生姓名:");
    scanf("%s", name);
    while (pStu != NULL)
    {
     if(strcmp(pStu->name, name) == 0)
     {
      hasFound = true;
      pStuArr[count++] = pStu;
      if(count % 100 == 0)
      {
       pStuArr = (Student**)realloc(pStuArr, count + 100);
      }
     }
     pStu = pStu->pNext;
    }
    if(hasFound)
    {
     setFontColor(LIGHTGREEN);
     printf(LIST_TITLE_1);
     setFontColor(WHITE);
     for (i = 0; i < count; i++)
     {
      printf("%d %s  %s %.2f %.2f %.2f %.2f\n", pStuArr[i]->num, pStuArr[i]->name, pStuArr[i]->sex, 
        pStuArr[i]->score[0], pStuArr[i]->score[1], pStuArr[i]->score[2], pStuArr[i]->averge);
     }

    }
    break;
   }
  case 3://根据语文成绩范围查询
  case 4://根据数学成绩范围查询
  case 5://根据英语成绩范围查询
  case 6://根据平均分范围查询
   {
    char *subjectStrArr[4] = {"语文", "数学", "英语", "平均"};
    printf("请输入要查询的%s成绩范围:", subjectStrArr[order - 3]);
    scanf("%d %d", &min, &max);
    while (pStu != NULL)
    {
     if(order < 6)// 3 ~ 5
     {
      score = pStu->score[order - 3];
     }
     else  //order = 6
     {
      score = pStu->averge;
     }
     if(score >= min && score <= max)
     {
      //找到符合条件的学生信息,则加入到指针数组中去
      hasFound = true;
      pStuArr[count++] = pStu;
      if(count % 100 == 0)
      {
       pStuArr = (Student**)realloc(pStuArr, count + 100);
      }
     }
     pStu = pStu->pNext;
    }
    if(hasFound)
    {
     setFontColor(LIGHTGREEN);
     printf(LIST_TITLE_1);
     setFontColor(WHITE);
     //打印指针数组中的学生信息
     for (i = 0; i < count; i++)
     {
      printf("%d %s  %s %.2f %.2f %.2f %.2f\n", pStuArr[i]->num, pStuArr[i]->name, pStuArr[i]->sex, 
       pStuArr[i]->score[0], pStuArr[i]->score[1], pStuArr[i]->score[2], pStuArr[i]->averge);
     }
     
    }
    break;
   }
  case 7://列出所有学生信息
   {
    hasFound = true;
    setFontColor(LIGHTGREEN);
    printf(LIST_TITLE_1);
    setFontColor(WHITE);
    while(pStu != NULL)
    {
     printf("%d %s  %s %.2f %.2f %.2f %.2f\n", pStu->num, pStu->name, pStu->sex, 
       pStu->score[0], pStu->score[1], pStu->score[2], pStu->averge);
     pStu = pStu->pNext;
    }
    break;
   }
  default:
   {
    goto lab_search;
   }
  }
  if(! hasFound)
  {
   printf("未能找到相应的学生信息!\n");
  }
  system("pause");
 }
lab_search:
 free(pStuArr);
}



bool deleteStudentInfo()
{
 char yesOrNo;
 int stuID;
 bool hasFound;
 Student* pStu, *pStu1;

 hasFound = false;
 pStu = G_pStuHead->pNext;
 pStu1 = G_pStuHead;

 printf("请输入欲删除的学生学号:");
 scanf("%d", &stuID);
 while (pStu != NULL)
 {
  if(pStu->num == stuID)
  {
   hasFound = true;
   break;
  }
  pStu1 = pStu;
  pStu = pStu->pNext;
 }
 if(hasFound)
 {
  printf("找到此学生的信息如下:\n");
  setFontColor(LIGHTGREEN);
  printf(LIST_TITLE_1);
  setFontColor(WHITE);
  printf("%d %s  %s %.2f %.2f %.2f %.2f\n", pStu->num, pStu->name, pStu->sex, 
    pStu->score[0], pStu->score[1], pStu->score[2], pStu->averge);
  printf("是否删除?Y/N");
  getchar();//过滤掉输入时的换行符
  scanf("%c", &yesOrNo);
  if(yesOrNo == 'y' || yesOrNo == 'Y')
  {
   pStu1->pNext = pStu->pNext;
   free(pStu);
   printf("已删除\n");
  }
  else
  {
   hasFound = false;
  }
 }
 else
 {
  printf("未找到对应学生的信息\n");
 }
 system("pause");
 return hasFound;
}



bool modifyStudentInfo()
{
 int order, count, i;
 int stuID;
 char name[20];
 char yesOrNo;
 bool hasModify;
 Student* pStu;
 Student** pStuArr;

 hasModify = false;
 count = 0;
 pStu = G_pStuHead->pNext;
 pStuArr = (Student**)malloc(4 * 100);//用于存放查找到的学生信息指针,这里定义指针数组是防止查询姓名出现重名

 printf("请输入以下序号,选择对应功能(1或2,否则返回上级菜单)\n");
 printf("1、输入学号查找学生\n");
 printf("2、输入姓名查找学生\n");
 scanf("%d", &order);

 if(order == 1)
 {
  printf("请输入要修改的学生学号:\n");
  scanf("%d", &stuID);
  while(pStu != NULL)
  {
   if(pStu->num == stuID)
   {
    pStuArr[count++] = pStu;
    break;
   }
   pStu = pStu->pNext;
  }
 }
 else if(order == 2)
 {
  printf("请输入要修改的学生姓名:\n");
  scanf("%s", name);
  while(pStu != NULL)
  {
   if(strcmp(pStu->name, name) == 0)
   {
    pStuArr[count++] = pStu;
    if(count % 100 == 0)//如果数组存放满了,则再次申请内存
    {
     pStuArr = (Student**)realloc(pStuArr, count + 100);
    }
   }
   pStu = pStu->pNext;
  }
 }
 else
 {
  return false;
 }
 if(count == 0)
 {
  printf("未能找到任何信息,是否继续修改?Y/N");
  getchar();//过滤掉输入时的换行符
  scanf("%c", &yesOrNo);
  if(yesOrNo == 'y' || yesOrNo == 'Y')
  {
   system("CLS");
   showSystemTitle();
   return modifyStudentInfo();
  }
 }
 else
 {
  printf("为您查找到%d个学生信息:\n   ", count);
  setFontColor(LIGHTGREEN);
  printf(LIST_TITLE);
  setFontColor(WHITE);
  for (i = 0; i < count; i++)
  {
   printf("%d、%d %s  %s %.2f %.2f %.2f\n", i + 1, pStuArr[i]->num, pStuArr[i]->name, pStuArr[i]->sex, 
    pStuArr[i]->score[0], pStuArr[i]->score[1], pStuArr[i]->score[2]);
  }

  printf("请输入您要修改的信息序号(1~%d),其他数字返回主菜单\n", count);
  scanf("%d", &order);
  if(order >= 1 && order <= count)
  {
   printf("请依次输入\n");
   setFontColor(LIGHTGREEN);
   printf(LIST_TITLE);
   setFontColor(WHITE);
   pStu = pStuArr[order - 1];
   scanf("%d %s %s %f %f %f", &pStu->num, pStu->name, pStu->sex, &pStu->score[0], &pStu->score[1], &pStu->score[2]);
   pStu->averge = (pStu->score[0] + pStu->score[1] + pStu->score[2]) / 3;
   hasModify = true;
  }
 }
 free(pStuArr);
 return hasModify;
}



bool checkStuIDExist(int stuID)
{
 Student* pStu;

 pStu = G_pStuHead->pNext;

 while(pStu != NULL)
 {
  if(pStu->num == stuID)
  {
   return true;
  }
  pStu = pStu->pNext;
 }
 return false;
}



bool addStudentInfo()
{
 printf("输入-1回车,返回上级菜单\n");
 setFontColor(LIGHTGREEN);
 printf(LIST_TITLE);
 setFontColor(WHITE);

 char c;
 bool hasAdd = false;
 Student* pStu = G_pStuHead;
 Student* pStuNew;

 while (pStu->pNext != NULL)
 {
  pStu = pStu->pNext;
 }

 while(1)
 {
  pStuNew = (Student*)malloc(sizeof(Student));
  scanf("%d", &pStuNew->num);
  if(pStuNew->num == -1)//输入-1返回主菜单
  {
   while ((c = getchar()) != EOF && c != '\n');//不停地使用getchar()获取缓冲中字符,直到获取的c是“\n”或文件结尾符EOF为止
   free(pStuNew);
   return hasAdd;
  }
  else if(checkStuIDExist(pStuNew->num))
  {
   while ((c = getchar()) != EOF && c != '\n');//不停地使用getchar()获取缓冲中字符,直到获取的c是“\n”或文件结尾符EOF为止
   printf("该学号已存在,请重新输入!\n");
   free(pStuNew);
   continue;
  }
  hasAdd = true;
  scanf("%s %s %f %f %f", pStuNew->name, pStuNew->sex, &pStuNew->score[0], 
   &pStuNew->score[1], &pStuNew->score[2]);
  pStuNew->averge = (pStuNew->score[0] + pStuNew->score[1] + pStuNew->score[2]) / 3;
  pStuNew->pNext = NULL;
  pStu->pNext = pStuNew;
  pStu = pStuNew;
 }

 return hasAdd;
}



bool orderToExecute(int order)
{
 bool succ;

 succ = false;
 if(order != Func_Save && order != Func_AutoSave && order!= Func_Export)
 {
  system("CLS");
  showSystemTitle();
 }

 switch (order)
 {
 case Func_Add://添加
  {
   succ = addStudentInfo();
   break;
  }
 case Func_Delete://删除
  {
   succ = deleteStudentInfo();
   break;
  }
 case Func_Modify://修改
  {
   succ = modifyStudentInfo();
   break;
  }
 case Func_Search://搜索
  {
   searchStudentInfo();
   break;
  }
 case Func_Sort://排序
  {
   succ = sortStudentInfo();
   break;
  }
 case Func_Save://保存
  {
   succ = saveStudentInfo();
   if(succ)
   {
    gotoxy(42, Func_Save + 3);
    setFontColor(LIGHTGREEN);
    printf("保存成功!");
    setFontColor(WHITE);
    gotodelete(0, Func_ExitSystem + 4, 2);
    gotoxy(0, Func_ExitSystem + 4);
   }
   return false;
  }
 case Func_AutoSave://设置自动保存
  {
   G_autoStore = ! G_autoStore;
   printAutoStoreInfo();
   orderToExecute(Func_Save);//保存配置
   break;
  }
 case Func_Vote://投票系统
  {
   voteSystem();
   break;
  }
 case Func_Export://导出所有学生信息(明文)
  {
   succ = exportStudentInfo();
   gotoxy(17, Func_Export + 3);
   setFontColor(LIGHTGREEN);
   if(succ)
   {
    printf("导出成功!");
   }
   else
   {
    printf("导出失败!");
   }
   setFontColor(WHITE);
   gotodelete(0, Func_ExitSystem + 4, 2);
   gotoxy(0, Func_ExitSystem + 4);
   return false;
  }
 default:
  {
   
   break;
  }
 }
 return succ;
}

int main(int argc, char* argv[])
{
 int order;
 bool succ;

 system("title 学生管理系统 by 机智蛋");
 order = 0;
 succ = false;
 G_pStuHead = (Student*)malloc(sizeof(Student));
 G_pStuHead->pNext = NULL;

 loadStudentInfo();

 while(1)
 {
  if(order != Func_Save && order != Func_AutoSave && order != Func_Export)//当输入这几个指令时不需要初始化屏幕
  {
   initScreen();
  }
  if(succ && order != Func_Save && G_autoStore)//执行自动保存
  {
   orderToExecute(Func_Save);
  }
  succ = false;

  do 
  {
   scanf("%d", &order);
   if(order >= Func_Add && order <= Func_ExitSystem)
   {
    break;
   }
   else
   {
    printf("指令错误,请重新输入\n");
   }
  } while (1);
  
  if(order == Func_ExitSystem)//退出
  {
   printf("欢迎下次继续使用,拜拜~~\n");
   return 0;
  }

  succ = orderToExecute(order);//执行功能

  
 }
 
 return 0;
}

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

--结束END--

本文标题: 使用C语言实现学生成绩管理系统

本文链接: https://www.lsjlt.com/news/135055.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 使用C语言实现学生成绩管理系统
    最近正在学习C语言,搞了一个学生成绩管理系统的小程序,代码粗陋,大佬勿喷。 先上图: 整个程序采用链表来管理学生成绩,保存学生成绩用的是 文件处理函数,使用 fopen(FileP...
    99+
    2022-11-12
  • C语言实现学生成绩管理系统项目
    本文实例为大家分享了C语言实现学生成绩管理系统项目,供大家参考,具体内容如下 1、数据结构:学生信息:学号、姓名、年龄、性别、3课成绩 2、功能: (1)  增加学生记录(...
    99+
    2022-11-13
  • C语言代码实现学生成绩管理系统
    某班有最多不超过 30 人(具体人数由键盘输人)参加期未考试,考试科目 最多不超过 6 门(具体门数由键盘输入,但不少于 3 门),学生成绩管理系统是一 个非常实用的程序,如果能够把...
    99+
    2022-11-13
  • C语言链表实现学生成绩管理系统
    目录一、课程设计题目及内容二、主要设计思路三、程序源码及具体注释(1)预处理指令(2)类型定义(3)函数原型(4)main函数定义(5)其他函数定义 四、运行示例五、注意事...
    99+
    2022-11-13
  • 怎么用C语言实现学生成绩管理系统
    这篇“怎么用C语言实现学生成绩管理系统”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“怎么用C语言实现学生成绩管理系统”文章吧...
    99+
    2023-06-29
  • C语言学生成绩管理系统源码
    本文实例为大家分享了C语言学生成绩管理系统的具体代码,供大家参考,具体内容如下 效果如下: 代码如下: #include <stdio.h> #include <...
    99+
    2022-11-13
  • C语言利用链表实现学生成绩管理系统
    链表是一种常见的基础数据结构,结构体指针在这里得到了充分的利用。 链表可以动态的进行存储分配,也就是说,链表是一个功能极为强大的数组,他可以在节点中定义多种数据类型,还可以根据需要随...
    99+
    2022-11-21
    C语言 链表 学生成绩管理系统 C语言 学生成绩管理系统 C语言 成绩管理系统
  • 怎么使用C语言代码实现学生成绩管理系统
    这篇文章主要介绍“怎么使用C语言代码实现学生成绩管理系统”,在日常操作中,相信很多人在怎么使用C语言代码实现学生成绩管理系统问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用C语言代码实现学生成绩管理系统...
    99+
    2023-06-30
  • C#实现学生成绩管理系统
    本文实例为大家分享了C#实现学生成绩管理系统的具体代码,供大家参考,具体内容如下 使用链表写学生成绩管理系统 链表可以灵活的展示增删改查 下面是结果演示 这是登录及部分添加 继续添...
    99+
    2022-11-13
    C#学生成绩管理系统 C#成绩管理系统 C#学生管理系统
  • 基于C语言实现简单学生成绩管理系统
    本文实例为大家分享了C语言实现简单学生成绩管理系统的具体代码,供大家参考,具体内容如下 一、系统主要功能 1、密码登录2、输入数据3、查询成绩4、修改成绩5、输出所有学生成绩6、退出...
    99+
    2022-11-13
  • C语言实现学生成绩管理系统课程设计
    目录设计要求完整代码运行结果本文实例为大家分享了C语言实现学生成绩管理系统的具体代码,供大家参考,具体内容如下 设计要求 设计学生成绩管理系统 要求如下: 1.输入学生信息2.统计学...
    99+
    2022-11-13
  • C语言嵌套链表实现学生成绩管理系统
    C语言嵌套链表实现学生成绩管理系统,供大家参考,具体内容如下 链表A,每个节点存放一个新的链表B1,B2,B3,B4,B5的头结点。 场景: 一个年级,相当链表A 该年级5个班,每个...
    99+
    2022-11-13
  • C语言实现简单学生成绩管理系统项目
    本文实例为大家分享了C语言实现学生成绩管理系统的具体代码,供大家参考,具体内容如下 系统界面及相关要求 1)系统运行,打开如下界面。列出系统帮助菜单(即命令菜单),提示输入命令。 ...
    99+
    2022-11-13
  • C++实现简单学生成绩管理系统
    本文实例为大家分享了C++实现学生成绩管理系统的具体代码,供大家参考,具体内容如下 一、问题描述 设计一个学生成绩管理程序,实现按班级完成对学生成绩信息的录入和修改,并用文件保存。实...
    99+
    2022-11-13
  • C#实现简单学生成绩管理系统
    本文实例为大家分享了C#实现学生成绩管理系统的具体代码,供大家参考,具体内容如下 C#作业 用循环结构/数组实现 进入启动页面 管理员身份登入 用户名:师晓峰密码:88481234...
    99+
    2022-11-13
    C#学生成绩管理系统 C#学生管理系统 C#成绩管理系统
  • C++实现学生成绩管理系统最新版
    学生成绩管理系统,供大家参考,具体内容如下 一、问题描述及功能要求 (1)输入同学的学号,姓名,三门科成绩(应用数学、大学英语、计算机应用基础) (2)可以计算出每个学生三门课的...
    99+
    2022-11-12
  • C++实现简单的学生成绩管理系统
    本文实例为大家分享了C++实现简单学生成绩管理系统的具体代码,供大家参考,具体内容如下 manage.h #include <iostream> #include <...
    99+
    2022-11-13
  • Java实现学生成绩管理系统
    本文实例为大家分享了Java实现学生成绩管理系统的具体代码,供大家参考,具体内容如下 新手练手小项目,主要练习面向对象、循环、数组、排序等等。 本人也是自学练手,代码有不正确的或不完...
    99+
    2022-11-12
  • python mysql实现学生成绩管理系统
    这学期在学python,感觉想写一个东西来巩固自己的基础,因为大二的时候我看过python,所以还是一共花了几个小时写了一个基于mysql的成绩管理系统,这个东西其实拿不出手,不过就...
    99+
    2022-11-12
  • C语言实现简单班级成绩管理系统
    前言: 有朋友最近在做c语言课设,要求写一个班级成绩管理系统,便写份简单的代码来玩。代码原创,未参考任何其他人的代码 程序要求 说明 本程序主要采用结构体数组本文件采用多文件编写,...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作