C语言学生管理系统源码分享

所属分类: 软件编程 / C 语言 阅读数: 86
收藏 0 赞 0 分享

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

#include<stdio.h> 
#include<stdlib.h> 
//结构体可以存放的学生信息最大个数,不可变变量
 int const MAX_LENGTH=100; 
 //学生信息结构体数组,最多可以存放100个学生信息 
 struct student{
 int id; //学号 
 char *name; //姓名 
 int age; //年龄
 float c_score; //C语言成绩 
 float english_score; //英语成绩 
 float database_score; //数据库成绩
 float total_score; //总分 
 }student_array[MAX_LENGTH]; 
 
 //学生信息数量 
 int student_count=0; 

 //函数声明 
 void print_all_students();
 void input_info(); 
 void query_info();
 void modify_info();
 void delete_info(); 
 void compute_total_score();
 void sort_info(); 
 int search_one_student(); 
 void print_one_student(struct student one);
 void delete_one_student(int student_index);
 char * get_item_name(int item_index);
 void modify_one_student(int student_index);
 void sort_by_id();
 void sort_by_c_score(); 
 void sort_by_english_score(); 
 void sort_by_database_score();

 //主函数 
 int main()
 {
 while(1)
 { 
 printf("请选择要使用的功能:\n");
 printf("录入信息,请输入1,然后回车!\n");
 printf("查询信息,请输入2,然后回车!\n"); 
 printf("修改信息,请输入3,然后回车!\n"); 
 printf("删除信息,请输入4,然后回车!\n"); 
 printf("计算总分,请输入5,然后回车!\n"); 
 printf("排序信息,请输入6,然后回车!\n"); 
 printf("输出全部,请输入0,然后回车!\n");
 printf("退出程序,请输入-1,然后回车!\n"); 
 //函数选择变量 
 int function=0;
 //输入选择的函数编号值 
 scanf("%d",&function); 
 //根据输入的函数编号,执行对应的功能
 switch(function){
 case -1: 
  exit(1);
 case 0: 
  print_all_students(); 
  break;
 case 1: 
  input_info();
  break;
 case 2:
  query_info();
  break; 
 case 3: 
  modify_info();
  break; 
 case 4: 
  delete_info();
  break; 
 case 5: 
  compute_total_score(); 
  break; 
 case 6:
  sort_info(); 
  break; 
 default: 
  printf("请输入正确的功能编号!!!\n\n");
  break;
 } 
 } 
 return 0; 
 } 
 
 //录入信息函数
void input_info()
 {
 printf("当前功能————录入信息!\n"); 
 //判断是否还有空间 
 if(student_count<MAX_LENGTH)
 {
 //声明一些临时变量
 int id=0; char *name=(char *)malloc(100);
 int age=0; float c_score=0; 
 float english_score=0;
 float database_score=0; 
 printf("请输入学生信息,格式为:学号,姓名,年龄,C语言成绩,英语成绩,数据库成绩\n");
 scanf("%d %s %d %f %f %f",&id,name,&age,&c_score,&english_score,&database_score);
 printf("学生信息校对:学号:%d,姓名:%s,年龄:%d,C语言成绩:%f,英语成绩:%f,数据库成绩:%f\n",id,name,age,c_score,english_score,database_score); 
 //学生信息加入结构体数组 
 student_array[student_count].id=id;
 student_array[student_count].name=name;
 student_array[student_count].age=age;
 student_array[student_count].c_score=c_score; 
 student_array[student_count].english_score=english_score; 
 student_array[student_count].database_score=database_score; 
 student_count++; 
 //是否继续录入信息
 printf("是否继续录入信息?继续请输入y,返回主菜单输入n\n");
 char go_on; 
 scanf("%s",&go_on); 
 if(go_on=='y')
 { 
  input_info();
 } 
 }
 else
 { 
 printf("学生结构体数据已满,可以删除一部分学生信息!\n");
 }
 } 


 //查询信息函数 
void query_info()
 {
 printf("当前功能————查询信息!\n");
 printf("请输入学生的学号\n"); 
 int id=0; 
 scanf("%d",&id);
 //查找输入id学生的序号
 int student_index=search_one_student(id);
 if(student_index!=-1)
 {
 print_one_student(student_array[student_index]); 
 }
 else
 { 
 printf("没有该学号的学生!\n");
 } 
 //是否继续查询信息 
 printf("是否继续查询信息?继续请输入y,返回主菜单输入n\n");
 char go_on; 
 scanf("%s",&go_on);
 if(go_on=='y') 
 query_info();
 } 
 
 
 //修改信息函数
void modify_info()
 { 
 printf("当前功能————修改信息!\n");
 printf("请输入学生的学号\n");
 int id=0; 
 scanf("%d",&id);
 //查找输入id学生的序号
 int student_index=search_one_student(id);
 if(student_index!=-1)
 { 
 modify_one_student(student_index); 
 }
 else
 { 
 printf("没有该学号的学生!\n");
 } 
} 
 
 
 //删除信息函数 
void delete_info()
 { 
 printf("当前功能————删除信息!\n");
 printf("请输入学生的学号\n"); 
 int id=0;
 scanf("%d",&id);
 //查找输入id学生的序号
 int student_index=search_one_student(id);
 if(student_index!=-1)
 { 
 //防止student_index被改变,传入temp_index计算
 int temp_index=student_index;
 print_one_student(student_array[temp_index]);
 //删除前进行确认
 printf("确定删除学号 %d 同学的信息?继续请输入y\n",id);
 char be_true; 
 scanf("%s",&be_true);
 if(be_true=='y')
 { 
  printf("%d\n", student_index); 
  //执行删除动作 
  delete_one_student(student_index); 
 } 
 }
 else
 { 
 printf("没有该学号的学生!\n"); 
 } 
 //是否继续删除信息
 printf("是否继续删除信息?继续请输入y,返回主菜单输入n\n");
 char go_on; 
 scanf("%s",&go_on);
 if(go_on=='y') 
 delete_info();
 } 
 
 
 //计算总分函数 
void compute_total_score()
 { 
 printf("当前功能————计算总分!\n"); 
 for (int i = 0; i < student_count; ++i)
 { 
  student_array[i].total_score=student_array[i].c_score+student_array[i].english_score+student_array[i].database_score; 
  print_one_student(student_array[i]);
  printf("总成绩:%f\n", student_array[i].total_score);
 } 
 printf("总分计算完成!!!\n");
 } 
 
 
 //成绩排序函数
void sort_info()
 {
 printf("当前功能————成绩排序!\n"); 
 printf("排序前所有学生信息如下:\n");
 print_all_students();
 int sort_type;
 while(1)
 { 
 printf("请输入排序字段,学号:1,C语言成绩:2,英语成绩:3,数据库成绩:4\n");
 scanf("%d",&sort_type);
 if(sort_type>=1&&sort_type<=4)
 break; 
 }
 switch(sort_type)
 { 
 case 1: 
 sort_by_id(); 
 break; 
 case 2:
 sort_by_c_score();
 break;
 case 3: 
 sort_by_english_score(); 
 break; 
 case 4: 
 sort_by_database_score(); 
 break;
 } 
 printf("排序后所有学生信息如下:\n");
 print_all_students(); 
 //是否继续删除信息 
 printf("是否继续排序信息?继续请输入y,返回主菜单输入n\n"); 
 char go_on;
 scanf("%s",&go_on);
 if(go_on=='y')
 sort_info();
 } 


//根据输入的学号,遍历结构体数组,若存在该学生,返回数组下标,不存在返回-1
int search_one_student(int id)
 {
 for (int i = 0; i < student_count; ++i)
 { 
 if(student_array[i].id==id)
 { 
  return i;
 }
 } 
 return -1; 
 } 


//输出某个学生的信息 
void print_one_student(struct student one)
{
 printf("学生信息:学号:%d,姓名:%s,年龄:%d,C语言成绩:%f,英语成绩:%f,数据库成绩:%f\n",one.id,one.name,one.age,one.c_score,one.english_score,one.database_score);
} 


//输出所有学生的信息
void print_all_students()
{ 
 if(student_count==0)
 {
 printf("暂无学生信息\n\n\n");
 }
 for (int i = 0; i < student_count; ++i)
 { 
 print_one_student(student_array[i]);
 } 
} 


void modify_one_student(int student_index)
{ 
 //修改前,输出学生信息 
 print_one_student(student_array[student_index]); 
 //字段序号初始值 
 int item_index=0; 
 //不允许修改学号字段 
 while(1)
 { 
 printf("请输入要修改的字段序号,姓名:1,年龄:2,C语言成绩:3,英语成绩:4,数据库成绩:5\n"); 
 scanf("%d",&item_index); 
 if(item_index>=1&&item_index<=5)
 break; 
 } 
 switch(item_index)
 { 
 case 1: 
  printf("请输入 %s 字段的新值\n", get_item_name(item_index)); 
  char* item_value_1=(char *)malloc(100);
  ; 
  scanf("%s",item_value_1);
  student_array[student_index].name=item_value_1;
  break;
 case 2:
  printf("请输入 %s 字段的新值\n", get_item_name(item_index));
  int item_value_2; 
  scanf("%d",&item_value_2);
  student_array[student_index].age=item_value_2;
  break;
 case 3: 
  printf("请输入 %s 字段的新值\n", get_item_name(item_index));
  float item_value_3;
  scanf("%f",&item_value_3); 
  student_array[student_index].c_score=item_value_3;
  break; 
 case 4:
  printf("请输入 %s 字段的新值\n", get_item_name(item_index));
  float item_value_4;
  scanf("%f",&item_value_4); 
  student_array[student_index].english_score=item_value_4;
  break; 
 case 5:
  printf("请输入 %s 字段的新值\n", get_item_name(item_index)); 
  float item_value_5;
  scanf("%f",&item_value_5); 
  student_array[student_index].database_score=item_value_5;
  break; 
 }
 printf("修改成功!新的学生信息如下:\n");
 //修改后输出学生信息 
 print_one_student(student_array[student_index]);
 //是否继续删除信息 
 printf("是否继续修改该学生信息?继续请输入y,返回主菜单输入n\n");
 char go_on; 
 scanf("%s",&go_on);
 if(go_on=='y') 
 modify_one_student(student_index);
} 


//删除数组对应序号的学生信息,把i位置后面的数据组元素向前移动覆盖i,student_count计数器减1 
void delete_one_student(int student_index)
{
 for (int i = student_index; i < student_count-1; ++i) 
 { 
 student_array[i]=student_array[i+1]; 
 } 
 student_count--;
 printf("删除完成\n\n\n"); 
} 


//根据输入的字段序号,返回字段名称
char * get_item_name(int item_index)
{ 
 switch(item_index)
 { 
 case 0:
  return "学号"; 
 case 1: 
  return "姓名"; 
 case 2:
  return "年龄";
 case 3:
  return "C语言成绩"; 
 case 4:
  return "英语成绩";
 case 5: 
  return "数据库成绩";
 default: 
  return "";
 } 
} 


//按照id排序,使用最简单的冒泡排序法
void sort_by_id()
{ 
 for (int i = 0; i < student_count; ++i)
 {
 for (int j = i; j < student_count; ++j) 
 { 
  if(student_array[i].id>student_array[j].id)
  {   
  struct student temp=student_array[i]; 
  student_array[i]=student_array[j];
  student_array[j]=temp;
  } 
 } 
 } 
 printf("按照 学号 排序完成\n");
} 


//按照C语言成绩排序,使用最简单的冒泡排序法
void sort_by_c_score()
{ 
 for (int i = 0; i < student_count; ++i)
 { 
 for (int j = i; j < student_count; ++j)
 {
  if(student_array[i].c_score>student_array[j].c_score)
  { 
  struct student temp=student_array[i];
  student_array[i]=student_array[j]; 
  student_array[j]=temp;
  } 
 } 
 }
 printf("按照 C语言成绩 排序完成\n");
} 


//按照英语成绩排序,使用最简单的冒泡排序法 
void sort_by_english_score()
{ 
 for (int i = 0; i < student_count; ++i)
 { 
 for (int j = i; j < student_count; ++j)
 { 
  if(student_array[i].english_score>student_array[j].english_score)
  { 
  struct student temp=student_array[i]; 
  student_array[i]=student_array[j]; 
  student_array[j]=temp;
  }
 }
 }
 printf("按照 英语成绩 排序完成\n"); 
} 


//按照数据库成绩排序,使用最简单的冒泡排序法 
void sort_by_database_score()
{ 
 for (int i = 0; i < student_count; ++i)
 { 
 for (int j = i; j < student_count; ++j)
 {
  if(student_array[i].database_score>student_array[j].database_score)
  { 
  struct student temp=student_array[i]; 
  student_array[i]=student_array[j]; 
  student_array[j]=temp;
  } 
 }
 } 
 printf("按照 数据库成绩 排序完成\n");
}

关于管理系统的更多内容请点击《管理系统专题》进行学习

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

更多精彩内容其他人还在看

用标准c++实现string与各种类型之间的转换

这个类在头文件中定义, < sstream>库定义了三种类:istringstream、ostringstream和stringstream,分别用来进行流的输入、输出和输入输出操作。另外,每个类都有一个对应的宽字符集版本
收藏 0 赞 0 分享

C++如何通过ostringstream实现任意类型转string

再使用整型转string的时候感觉有点棘手,因为itoa不是标准C里面的,而且即便是有itoa,其他类型转string不是很方便。后来去网上找了一下,发现有一个好方法
收藏 0 赞 0 分享

C/C++指针小结

要搞清一个指针需要搞清指针的四方面的内容:指针的类型,指针所指向的类型,指针的值或者叫指针所指向的内存区,还有指针本身所占据的内存区
收藏 0 赞 0 分享

C++ 类的静态成员深入解析

在C++中类的静态成员变量和静态成员函数是个容易出错的地方,本文先通过几个例子来总结静态成员变量和成员函数使用规则,再给出一个实例来加深印象
收藏 0 赞 0 分享

C++类的静态成员初始化详细讲解

通常静态数据成员在类声明中声明,在包含类方法的文件中初始化.初始化时使用作用域操作符来指出静态成员所属的类.但如果静态成员是整型或是枚举型const,则可以在类声明中初始化
收藏 0 赞 0 分享

C++类静态成员与类静态成员函数详解

静态成员不可在类体内进行赋值,因为它是被所有该类的对象所共享的。你在一个对象里给它赋值,其他对象里的该成员也会发生变化。为了避免混乱,所以不可在类体内进行赋值
收藏 0 赞 0 分享

C++中的friend友元函数详细解析

友元可以是一个函数,该函数被称为友元函数;友元也可以是一个类,该类被称为友元类。友元函数的特点是能够访问类中的私有成员的非成员函数。友元函数从语法上看,它与普通函数一样,即在定义上和调用上与普通函数一样
收藏 0 赞 0 分享

static全局变量与普通的全局变量的区别详细解析

以下是对static全局变量与普通的全局变量的区别进行了详细的分析介绍,需要的朋友可以过来参考下,希望对大家有所帮助
收藏 0 赞 0 分享

C++ explicit关键字的应用方法详细讲解

C++ explicit关键字用来修饰类的构造函数,表明该构造函数是显式的,既然有"显式"那么必然就有"隐式",那么什么是显示而什么又是隐式的呢?下面就让我们一起来看看这方面的知识吧
收藏 0 赞 0 分享

教你5分钟轻松搞定内存字节对齐

随便google一下,人家就可以跟你解释的,一大堆的道理,我们没怎么多时间,讨论为何要对齐.直入主题,怎么判断内存对齐规则,sizeof的结果怎么来的,请牢记以下3条原则
收藏 0 赞 0 分享
查看更多