c语言学生信息管理系统-学习结构体
#include<stdio.h>
#include<stdlib.h>
//结构体可以存放的学生信息最大个数,不可变变量
int const MAX_LENGTH=;
//学生信息结构体数组,最多可以存放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=; //函数声明
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()
{
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=;
//输入选择的函数编号值
scanf("%d",&function);
//根据输入的函数编号,执行对应的功能
switch(function){
case -:
exit();
case :
print_all_students();
break;
case :
input_info();
break;
case :
query_info();
break;
case :
modify_info();
break;
case :
delete_info();
break;
case :
compute_total_score();
break;
case :
sort_info();
break;
default:
printf("请输入正确的功能编号!!!\n\n");
break;
}
}
return ;
} //录入信息函数
void input_info()
{
printf("当前功能————录入信息!\n");
//判断是否还有空间
if(student_count<MAX_LENGTH)
{
//声明一些临时变量
int id=; char *name=(char *)malloc();
int age=; float c_score=;
float english_score=;
float database_score=;
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=;
scanf("%d",&id);
//查找输入id学生的序号
int student_index=search_one_student(id);
if(student_index!=-)
{
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=;
scanf("%d",&id);
//查找输入id学生的序号
int student_index=search_one_student(id);
if(student_index!=-)
{
modify_one_student(student_index);
}
else
{
printf("没有该学号的学生!\n");
}
} //删除信息函数
void delete_info()
{
printf("当前功能————删除信息!\n");
printf("请输入学生的学号\n");
int id=;
scanf("%d",&id);
//查找输入id学生的序号
int student_index=search_one_student(id);
if(student_index!=-)
{
//防止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 = ; 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()
{
printf("请输入排序字段,学号:1,C语言成绩:2,英语成绩:3,数据库成绩:4\n");
scanf("%d",&sort_type);
if(sort_type>=&&sort_type<=)
break;
}
switch(sort_type)
{
case :
sort_by_id();
break;
case :
sort_by_c_score();
break;
case :
sort_by_english_score();
break;
case :
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 = ; i < student_count; ++i)
{
if(student_array[i].id==id)
{
return i;
}
}
return -;
} //输出某个学生的信息
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==)
{
printf("暂无学生信息\n\n\n");
}
for (int i = ; 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=;
//不允许修改学号字段
while()
{
printf("请输入要修改的字段序号,姓名:1,年龄:2,C语言成绩:3,英语成绩:4,数据库成绩:5\n");
scanf("%d",&item_index);
if(item_index>=&&item_index<=)
break;
}
switch(item_index)
{
case :
printf("请输入 %s 字段的新值\n", get_item_name(item_index));
char* item_value_1=(char *)malloc();
;
scanf("%s",item_value_1);
student_array[student_index].name=item_value_1;
break;
case :
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 :
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 :
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 :
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-; ++i)
{
student_array[i]=student_array[i+];
}
student_count--;
printf("删除完成\n\n\n");
} //根据输入的字段序号,返回字段名称
char * get_item_name(int item_index)
{
switch(item_index)
{
case :
return "学号";
case :
return "姓名";
case :
return "年龄";
case :
return "C语言成绩";
case :
return "英语成绩";
case :
return "数据库成绩";
default:
return "";
}
} //按照id排序,使用最简单的冒泡排序法
void sort_by_id()
{
for (int i = ; 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 = ; 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 = ; 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 = ; 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");
}
转发自:http://mp.weixin.qq.com/s/MGaBxgZGJ5WFBieVLMmdCg
c语言学生信息管理系统-学习结构体的更多相关文章
- 在Main中定义student的结构体,进行年龄从大到小依次排序录入学生信息。(结构体的用法以及冒泡排序)
using System; using System.Collections; using System.Collections.Generic; using System.Linq; using S ...
- C语言学生信息管理系统项目源码
#include //包含printf().scanf().gets().puts().getchar()函数 #include //包含malloc()函数 #include //包含s ...
- 【转载】C语言综合实验1—学生信息管理系统
http://www.cnblogs.com/Anker/archive/2013/05/06/3063436.html 实验题目:学生信息管理系统 实验要求:用户可以选择1-7可以分别进行学生信息的 ...
- C语言小练习之学生信息管理系统
C语言小练习之学生信息管理系统 main.c文件 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 2 ...
- 学生信息管理系统(c语言)
①注意: 程序中使用了sleep()函数.system()函数 关于 sleep() 函数 sleep() 函数的头文件和用法会因环境的不同而有所不同. 具体见-sleep()函数功能及用法 关于sy ...
- 基于数组或链表的学生信息管理系统(小学期C语言程序实训)
1.基于数组的学生信息管理系统 实验内容: 编写并调试程序,实现学校各专业班级学生信息的管理.定义学生信息的结构体类型,包括:学号.姓名.专业.班级.3门成绩. 实验要求: (1) main函数:以菜 ...
- C语言练习-学生信息管理系统
题目要求: 学生信息管理系统struct studentInfo{ int id; char name[128]; int age; char sex; int c_score; int cpp_sc ...
- 大一C语言结课设计之《学生信息管理系统》
第一次写这么长的程序,代码仅供參考,有问题请留言. /* ** 学生信息管理系统 ** IDE:Dev-Cpp 4.9.9.2 ** 2014-6-15 */ #include <stdio.h ...
- Android(java)学习笔记195:学生信息管理系统案例(SQLite + ListView)
1.首先说明一个知识点,通常我们显示布局文件xml都是如下: setContentView(R.layout.activity_main): 其实每一个xml布局文件就好像一个气球,我们可以使用Vie ...
随机推荐
- 程序员教程-11章-Java程序设计
自己是学java的,先看第十一章java吧. 列出章节目录,便于自己回忆内容. 11.1 Java语言概述 1 Java语言的特点 2 Java开发环境 11.2 Java语言基础 11.2.1 基本 ...
- [ERR] Not all 16384 slots are covered by nodes.
redis集群开不起来,用redis-cli连接的时候出现如下错误: CLUSTERDOWN The cluster is down 然后使用redis-trib.rb检查: ./redis-trib ...
- 数学分析中jensen不等式由浅入深进行教学(转)
中国知网:数学分析中Jensen不等式由浅入深进行教学
- oracle 网络环境配置
PLSQL Developer连接Oracle11g 64位数据库配置详解 最近换了台64bit的电脑,所以oracle数据库也跟着换成了64bit的,不过 问题也随之产生,由于plsql devel ...
- Mysql修改密码办法
方法1: 用SET PASSWORD命令 首先登录MySQL. 格式:mysql> set password for 用户名@localhost = password('新密码'); 例子:my ...
- spring学习笔记(三)
spring jdbc spring tx 1.spring的jdbc模板 Spring提供了很多持久层技术的模板类简化编程: 1.1.jdbc模板的基本使用 @Test // JDBC模板的基本使用 ...
- Loadrunner进行参数化
Loadrunner进行参数化 Loadrunner中进行参数化,这里有三种方法. 对需要多次使用的变量进行参数化,比如登录信息的用户名和密码,首先需要选中需要参数化的值,然后右键选择Replace ...
- 关于空指针NULL、野指针、通用指针
http://www.cnblogs.com/losesea/archive/2012/11/16/2772590.html 首先说一下什么是指针,只要明白了指针的含义,你就明白null的含义了.假设 ...
- Plants vs. Zombies(二分好题+思维)
Plants vs. Zombies http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=5819 BaoBao and DreamG ...
- 硬盘的 read0 read 1
Read 0:组建的时候必须2块容量相同的硬盘,每个程序的数据以一定的大小分别写在两个硬盘里,读的时候从两个硬盘里一起读,这种阵列方式理论上硬盘的读写速度是一块硬盘的2倍,实际应用中大约速度比一块硬盘 ...