Ⅰ c语言图书管理系统
用户名 yhk
密码 1234
Ⅱ 急求一个C语言管理系统
------------------------------------------//Copyright(C)2009沈阳工程学院信息安全工作室//版权所有。////文件名:模拟停车场问题.cpp//文件功能描述:模拟停车场问题//////创建标识:20091214////修改标识:20091218//修改描述:完成编码//----------------------------------------------------------------*///头文件#include#include#include#include//常量定义#defineMAX_STOP4//定义停车场最大停车数#defineMAX_PLATE10//定义车牌号最大长度#defineTIME_COUNT"秒"//定义时间单位#defineTIME_MS_TO_CONUT1000//定义时间进制,意为由TIME_COUNT到毫秒的进制#defineUNIT_PRICE10//定义单位时间收费标准usingnamespacestd;//使用std命名空间//数据结构定义//定义存储汽车信息的结构体typedefstruct{charlicense_plate[MAX_PLATE];//汽车牌照号码,定义为一个字符指针类型charstate;//汽车当前状态,字符p表示停放在停车位上,字符s表示停放在便道上,每辆车的初始状态用字符i来进行表示inttime;//汽车停入停车场时的时间,用来计时收费}CAR;//定义模拟停车场的栈结构typedefstruct{CARSTOP[MAX_STOP];//汽车信息的存储空间inttop;//用来指示栈顶位置的静态指针}SeqStack;//定义模拟便道的队列结构typedefstructnode{CARWAIT;//汽车信息的存储空间structnode*next;//用来指示队列位置的动态指针}QNode;//链队列节点的类型//定义链队列的收尾指针typedefstruct{QNode*front,*rear;}LQueue;//将头尾指针封装在一起的链队//函数声明intEmpty_LQueue(LQueue*q);//判队空intLeaveCheck(SeqStackparking,char*license_plate);//检查离开的车是否在停车场中intQueueLength(LQueue*q);//判队长度intOut_LQueue(LQueue*&sidewalk,char*license_plate);//出队操作intStackEmpty(SeqStackparking);//判断栈是否为空intStackFull(SeqStackparking);//判断栈是否为满intStackPop(SeqStack&parking);//出栈操作intStackTop(SeqStackparking,char*license_plate,int&time);//取栈顶元素voidCar_come(SeqStack&parking,LQueue*&sidewalk);//有车到来时的操作voidCar_leave(SeqStack&parking,LQueue*&sidewalk);//有车离开的操作voidDisplay(SeqStackparking);//显示停车场内的所有信息调试时用voidInitStack(SeqStack&parking);//初始化栈voidInitList(LQueue*&sidewalk);//初始化队列voidIn_LQueue(LQueue*&sidewalk,char*license_plate);//进队操作voidInput_Check(char*license_plate);////检验输入的车牌是否合法voidStackPush(SeqStack&parking,char*license_plate,intstop_time);//进栈操作voidmain(){//定义变量SeqStackparking;LQueue*sidewalk=NULL;char*choice=newchar;intflag=1;//定义一个变量判断是否退出//初始化一个为空的停车场InitStack(parking);//初始化一个为空的便道InitList(sidewalk);//运行界面及功能选择while(flag){coutrear=NULL;}//入队voidIn_LQueue(LQueue*&sidewalk,char*license_plate){QNode*car_on_sidewalk;car_on_sidewalk=(QNode*)malloc(sizeof(QNode));//为新节点开辟新空间strcpy(car_on_sidewalk->WAIT.license_plate,license_plate);//将数据写入节点car_on_sidewalk->WAIT.state='s';//写入停车信息car_on_sidewalk->WAIT.time=GetTickCount();//写入停车时间car_on_sidewalk->next=NULL;if(Empty_LQueue(sidewalk))//队空则创建第一个节点sidewalk->front=sidewalk->rear=car_on_sidewalk;else{//队非空插入队尾sidewalk->rear->next=car_on_sidewalk;sidewalk->rear=car_on_sidewalk;}}//判队空intEmpty_LQueue(LQueue*q){if(q->front==NULL)return1;elsereturn0;}//判队长度返回队长intQueueLength(LQueue*q){QNode*p=q->front;inti=0;while(p!=NULL){i++;p=p->next;}returni;}//出队成功返回1队空返回0intOut_LQueue(LQueue*&sidewalk,char*license_plate){QNode*car_on_sidewalk;if(Empty_LQueue(sidewalk))//如果队空返回0return0;car_on_sidewalk=sidewalk->front;strcpy(license_plate,car_on_sidewalk->WAIT.license_plate);//取出队头元素if(sidewalk->front==sidewalk->rear)//队中只有一个元素sidewalk->front=sidewalk->rear=NULL;//删除元素elsesidewalk->front=sidewalk->front->next;//队头指针后移free(car_on_sidewalk);//释放指针return1;}//检查离开的车是否在停车场中返回车在停车场中位置不在则返回0intLeaveCheck(SeqStackparking,char*license_plate){intflag=parking.top+1;//定义变量记录当前车在停车场中位置if(StackEmpty(parking))return0;else{//查找离开车所在位置while(parking.top!=-1&&strcmp(parking.STOP[parking.top].license_plate,license_plate)!=0){flag--;parking.top--;}returnflag;}}//检验输入的车牌是否合法voidInput_Check(char*license_plate){intflag=1;inti;stringtmpstr;while(flag){cin>>tmpstr;getchar();if(tmpstr.length()
Ⅲ c语言(我的藏书管理系统)
#include<stdio.h>
#include<stdlib.h>
#include<string.h>//定义字符数组
#include<conio.h>
static int number=0;
struct Book_type{//书名、ISBN、出版时间、现在状态。
char Bname[10];
int isbn;
char data[10];
char now[10];
};
struct Book_type book[100];
void init_book(){
strcpy(book[number].Bname,"数字信号处理");
strcpy(book[number].data,"2018-10-20");
book[number].isbn=1;
strcpy(book[number++].now,"out");
strcpy(book[number].Bname,"电路分析");
strcpy(book[number].data,"2014-06-02");
strcpy(book[number].now,"in");
book[number++].isbn=2;
}
void cangshu(){
int i=0;
while(i<number){
printf("书名:%s\n",book[i].Bname);
printf("ISBN:%d\n",book[i].isbn);
printf("出版时间:%s\n",book[i].data);
printf("现在状态:%s\n",book[i].now);
i++;
}
}
void tianshu(int n){
int total=number+n;
for (;number <total; number++)
{
printf("请输入第%d个书的信息以空格区分(1、书名 2、ISBN 3、出版时间 4、现在状态):\n", number+1);
scanf("%s %d %s %s", &book[number].Bname, &book[number].isbn, &book[number].data, &book[number].now);/*%c前面要加空格, 不然输入时会将空格赋给%c*/
}
}
void xiugai(int c){
printf("请输入第%d个书的信息以空格区分(1、书名 2、ISBN 3、出版时间 4、现在状态):\n", c-1);
scanf("%s %d %s %s", &book[c-1].Bname, &book[c-1].isbn, &book[c-1].data, &book[c-1].now);
printf("修改成功\n");
}
void chaxun(int n){
if(n>number){
printf("查无此书\n");
return;
}
printf("书名:%s\n",book[n-1].Bname);
printf("ISBN:%d\n",book[n-1].isbn);
printf("出版时间:%s\n",book[n-1].data);
printf("现在状态:%s\n",book[n-1].now);
}
void jm() //显示页面
{
system ("cls");
printf("******************************************************\n");
printf("* *\n");
printf("* 1、显示我的藏书 *\n");
printf("* 2、添加新书 *\n");
printf("* 3、修改 *\n");
printf("* 4、查询 *\n");
printf("* 5、结束 *\n");
printf("* *\n");
printf("*******************************************************\n");
return ;
}
void mima()
{
char password[10]={0}; //界面格式
char pass[10]="1234";
printf("********************************\n");
printf("* *\n");
printf("* 请输入密码: *\n");
printf("* *\n");
printf("********************************\n");
printf("请输入密码:\n");
scanf("%s",password);
while(strcmp(pass,password)!=0){
printf("密码错误请重新输入\n");
scanf("%s",password);
}
}
void main()//main函数
{
int newbook,flag=1,change=0;
int choose=0;
init_book();
mima();
jm();
while(flag){
printf("请选择功能\n");
scanf("%d",&choose);
switch (choose)
{
case 1:
cangshu();
break;
case 2:
printf("请输入需要新添加几本书\n");
scanf("%d",&newbook);
tianshu(newbook);
break;
case 3:
printf("请输入需要修改第几本:\n");
scanf("%d",&change);
xiugai(change);
break;
case 4:
printf("请输入需要查询的序列号:\n");
scanf("%d",&change);
chaxun(change);
break;
case 5:
flag=0;
break;
default:
break;
}
}
system("pause");
}
大概就这样,基本上完善了功能
Ⅳ c语言班级管理系统
在谭浩强C语言程序设计里有关于文件的介绍,如需写出具体程序,追问一下。
Ⅳ C语言程序 如何编写管理系统
C语言编程的规则
C语言源程序的编程语法归纳如下:
1,强制性规则
1,一个C语言源程序必须有且只有一个MAIN函数.
2,函数名后必须紧跟圆括号对,函数体放在右圆括号")"后的花括号对"{}"中.
3,每个程序体(包括函数的函数体,含有多条语句的选择结构和循环结构中的语句序列)必须用一对花括号括起来.
4,文件包含预处理命令,#INCLUDE<*.H应置于源程序的开始位置.
5,语句未尾必须有分号,而预处理命令和函数首部的未尾及右花括号之后不要分号.
6,同一字母大,小写意义不同,关键字和标准库函数名必须用小写.
7,变量必须先定义,后使用
8,除已有明显间隔符外,标识符,关键字之间必须有至少一个空格9,注解必须包含在"/* */符号之间
Ⅵ 学生管理系统C语言
#include<stdio.h>
#define N 30
int Input1(long xuehao[],int score[],int n);
int Sum(int score[],int n);
int No3(long xuehao[],int score[],int n);
int No4(long xuehao[],int score[],int n);
int No5(long xuehao[],int score[],int n);
int No6(int score[],int n);
int Input1(long xuehao[],int score[],int n){
int i;
printf("输入学号和成绩\n");
for(i=0;i<n;i++){
scanf("%ld %d",&xuehao[i],&score[i]);
}
// for(i=0;i<n;i++){
// printf("学号%ld 成绩%d\n",xuehao[i],score[i]);
//}
}
int Sum(int score[],int n){
int sum;
float aver;
sum=0; aver=0;
int i;
for(i=0;i<n;i++){
sum=sum+score[i];
}
aver=(float)sum/n;
printf("总分为%d,平均分为%.2f",sum,aver);
}
int No3(long xuehao[],int score[],int n){
int i,j,k,temp1;
long temp2;
for(i=0;i<n-1;i++){
k=i;
for(j=i+1;j<n;j++){
if(score[j]>score[k]){ k=j; }
}
if(k!=i){
/*交换成绩*/
temp1=score[k];score[k]=score[i];score[i]=temp1;
/*交换学号*/
temp2=xuehao[k];xuehao[k]=xuehao[i];xuehao[i]=temp2;
}
}
int a;
printf("按成绩高低排序\n");
for(a=0;a<n;a++){
printf("学号%ld 成绩%d\n",xuehao[a],score[a]);
}
}
int No4(long xuehao[],int score[],int n){
int i,j,k,temp1;
long temp2;
for(i=0;i<n-1;i++){
k=i;
for(j=i+1;j<n;j++){
if(xuehao[j]>xuehao[k]){ k=j; }
}
if(k!=i){
/*交换学号*/
temp1=xuehao[k];xuehao[k]=xuehao[i];xuehao[i]=temp1;
/*交换成绩*/
temp2=score[k];score[k]=score[i];score[i]=temp2;
}
}
int a;
printf("按学号排序\n");
for(a=0;a<n;a++){
printf("学号%ld 成绩%d\n",xuehao[n-1-a],score[n-1-a]);
}
}
int No5(long xuehao[],int score[],int n){
int i,a;
long x;
No3(xuehao,score,n);
printf("输入学号\n");
scanf("%ld",&x);
for(i=0;i<n;i++){
if(xuehao[i]==x){
a=i;
break;
}
}
printf("学号%ld 成绩%d 排名%d\n ",xuehao[a],score[a],a+1);
}
int No6(int score[],int n){
int i;
int a=0,b=0,c=0,d=0,e=0;
float a1,b1,c1,d1,e1;
for(i=0;i<n;i++){
if(score[i]>=90) {a++; }
else if(score[i]>=80){b++; }
else if(score[i]>=70) {c++; }
else if(score[i]>=60) {d++; }
else {e++; printf("e is%d",e);}
}
a1=(float)a/n*100;b1=(float)b/n*100;c1=(float)c/n*100;d1=(float)d/n*100;e1=(float)e/n*100;
printf("优秀%d %.1f%%\n良好%d %.1f%% \n中等%d %.1f%% \n及格%d %.1f%%\n不及格%d %.1f%%\n",a,a1,b,b1,c,c1,d,d1,e,e1);
// printf("%.2f %.2f %.2f %.2f %.2f\n",a1,b1,c1,d1,e1);
}
int No7(long xuehao[],int score[],int n){
int i;
for(i=0;i<n;i++){
printf("学号%ld 成绩%d\n",xuehao[i],score[i]);
}
Sum(score,n);
}
main(){
int score[N];
long xuehao[N];
int n;
printf("1.Input record\n");
printf("2.caculate total and average score of course\n");
printf("3.sort in descending order by score\n");
printf("4.sort in ascending order by score\n");
printf("5.search by number \n");
printf("6.statistic analysis\n");
printf("7.list record\n");
printf("0.exit\n");
int num;
printf("人数(不许超过30!不许超过30!不许超过30)\n");
do{scanf("%d",&n);}while(n<1 || n>30);
if(n>30) printf("wrong!\n");
//printf("输入选项\n");
//scanf("%d",&num);
int p=1; //控制结束
do{
printf("输入选项\n");
scanf("%d",&num);
switch(num){
case 1:
Input1(xuehao,score,n);
break;
case 2: Sum(score,n);
break;
case 3: No3(xuehao,score,n);
break;
case 4: No4(xuehao,score,n);
break;
case 5: No5(xuehao,score,n);
break;
case 6: No6(score,n);
break;
case 7: No7(xuehao,score,n);
break;
case 0: p=-1;
break;
}
}while(p!=-1);
return 0;
}
Ⅶ c语言--学生信息管理系统
人才,给5分想拿这么大的一个程序。
Ⅷ C语言编程一个管理系统
C语言写这么一个很难,建议用java,c#或是c++之类的,会比较容易
Ⅸ 用C语言编写一个学生管理系统。
概述
单纯只用多个数组管理学生成绩信息,不使用结构体,该程序最主要的难点是依据学号或总成绩对学生信息进行排序,借助了临时数组来标记排好序的下标。
运行结果如下:
输入数据:
贴上代码(有点多)
#include <stdio.h>
#include <stdlib.h> //exit函数头文件
#include <string.h> //字符串相关操作头文件
#define MAX_STUDENT 30 //最大学生数
//函数声明,本程序共10个子函数,每个函数对应一个操作
void student_scanf(int n);
void student_printf(int n);
int student_find_name(int n);
int student_find_num(int n);
void student_sort_num(int n);
void student_sort_sum(int n);
int student_alter_num(int n);
int student_alter_name(int n);
int student_delete_num(int n);
int student_delete_name(int n);
//全局数组变量,用于存储学生信息
char names[MAX_STUDENT][50];
int math[MAX_STUDENT];
int english[MAX_STUDENT];
int computer[MAX_STUDENT];
int sum[MAX_STUDENT];
int num[MAX_STUDENT];
//以下变量用于学生信息数组排序,作为临时数组
int temp_num[MAX_STUDENT];
char temp_names[MAX_STUDENT][50];
int temp_math[MAX_STUDENT];
int temp_english[MAX_STUDENT];
int temp_computer[MAX_STUDENT];
int temp_sum[MAX_STUDENT];
//sort数组存储排好序的学号或姓名下标
int sort[MAX_STUDENT];
//循环全局变量
int i, j;
//main主函数
int main(void)
{
int choice,n;
while (1)
{
printf("************************************* ");
printf("欢迎使用学生成绩管理系统 ");
printf("[1] 输入所有学生信息 ");
printf("[2] 输出所有学生成绩 ");
printf("[3] 按学号查找某个学生信息 ");
printf("[4] 按姓名查找某个学生信息 ");
printf("[5] 按学号对学生排序 ");
printf("[6] 按总成绩对学生排序 ");
printf("[7] 按学号修改某个学生信息 ");
printf("[8] 按姓名修改某个学生信息 ");
printf("[9] 按学号删除某个学生信息 ");
printf("[10] 按姓名删除某个学生信息 ");
printf("[0] 退出程序 ");
printf("请输入您的选择(0 - 9):");
scanf("%d",&choice);
printf("**************************************) ");
switch (choice)
{
case 1://录入;
printf("请输入录入的学生信息数: ");
scanf("%d",&n);
student_scanf(n);
break;
case 2://输出;
student_printf(n);
break;
case 3://根据学号查找
student_find_num(n);
break;
case 4://根据姓名查找
student_find_name(n);
break;
case 5://按学号排序
student_sort_num(n);
break;
case 6://按姓名排序
student_sort_sum(n);
break;
case 7://按学号修改
student_alter_num(n);
break;
case 8://按姓名修改
student_alter_name(n);
break;
case 9://按学号删除
student_delete_num(n);
n--;
break;
case 10://按姓名删除
student_delete_name(n);
n--;
break;
case 0://退出程序
printf("退出程序 ");
printf("程序结束,谢谢使用! ");
exit(0);
default:
printf("您输入的菜单有误。请重新输入! ");
}
}
return 0;
}
//1.输入信息
void student_scanf(int n)
{
for (i = 0; i<n; ++i)
{
printf(" 请输入第%d个学生的信息: ", i + 1);
printf(" 学号:");
scanf("%d", &num[i]);
printf(" 姓名:");
scanf("%s", names[i]);
printf(" 数学成绩:");
scanf("%d", &math[i]);
printf(" 英语成绩:");
scanf("%d", &english[i]);
printf(" 计算机成绩:");
scanf("%d", &computer[i]);
//计算总成绩
sum[i] = math[i] + english[i] + computer[i];
}
}
//2.打印信息
void student_printf(int n)
{
printf(" 学号 姓名 数学成绩 英语成绩 计算机成绩 总成绩 ");
printf("---------------------------------------------------------- ");
for (i = 0; i<n; ++i)
{
printf("%d %s %d %d %d %d ", num[i], names[i], math[i], english[i], computer[i], sum[i]);
}
printf("------------------------------------------------------- ");
}
//3.按学号查找
int student_find_num(int n)
{
int nums;
int result;
printf("请输入待查找的学生学号:");
scanf("%d",&nums);
result= -1;
for (i = 0; i<n; ++i)
{
if (nums == num[i])
{
result = i;
break;
}
}
//最后判断q值
if (result == -1)
{
printf("没有该学生信息! ");
return 0;
}
else
{
//先打印表头
printf(" 学号 姓名 数学成绩 英语成绩 计算机成绩 总成绩 ");
//再打印数据
printf("%d %s %d %d %d %d ", num[result], names[result], math[result], english[result], computer[result], sum[result]);
printf("打印出查找结果! ");
}
return 1;
}
//4.用姓名查找成绩
int student_find_name(int n)
{
char name[200];
int result;
printf("请输入待查找的学生姓名:");
scanf("%s", name);
result = -1;
for (i = 0; i<n; ++i)
{
if (strcmp(name, names[i]) == 0)
{
result = i;
break;
}
}
if (result == -1)
{//未找到结果
printf("没有该学生信息! ");
return 0;
}
else//找到结果
{
printf(" 学号 姓名 数学成绩 英语成绩 计算机成绩 总成绩 ");
printf("%d %s %d %d %d %d ", num[result], names[result], math[result], english[result], computer[result], sum[result]);
printf("已完成查找! ");
}
return 1;
}
//5.按学号排序
void student_sort_num(int n)
{
int min,max;
for(i=0; i<n; ++i) //复制临时数组
{
temp_num[i] = num[i];
}
max = 0; //查找学号最大值,将其下标存至sort数组的最后一个值中
for(j=1; j<n; j++)
{
if(temp_num[max]<temp_num[j])
max = j;
}
sort[n-1] = max; //sort数组的最后一个数
for(i=0; i<n-1; ++i)
{
min = i; //查找学号最小值
for(j=0; j<n; ++j)
{
if(temp_num[min]>temp_num[j])
min = j;
}
//sort数组记录排序的学生信息的下标
sort[i] = min;
temp_num[min] = temp_num[max]; //利用临时数组将查找过的学生信息的学号设为最大值,排除查找干扰
}
for(i=0; i<n; ++i) //再复制一次临时数组
{
temp_num[i] = num[i];
strcpy(temp_names[i],names[i]);
temp_math[i] = math[i];
temp_english[i] = english[i];
temp_computer[i] = computer[i];
temp_sum[i] = sum[i];
}
for(i=0; i<n; i++) //按照下标对原数组进行修改
{
num[i] = temp_num[sort[i]];
strcpy(names[i],temp_names[sort[i]]);
math[i] = temp_math[sort[i]];
english[i] = temp_english[sort[i]];
computer[i] = temp_computer[sort[i]];
sum[i] = temp_sum[sort[i]];
}
printf("排序完毕,请按菜单键2查看排序结果! ");
return ;
}
//6.按总成绩排序
void student_sort_sum(int n)
{
int min,max;
for(i=0; i<n; ++i) //复制临时数组
{
temp_sum[i] = sum[i];
}
max = 0; //查找总成绩最大值,将其下标存至sort数组的最后一个值中
for(j=1; j<n; j++)
{
if(temp_sum[max]<temp_sum[j])
max = j;
}
sort[n-1] = max; //sort数组的最后一个数
for(i=0; i<n-1; ++i)
{
min = i; //查找总成绩最小值
for(j=0; j<n; ++j)
{
if(temp_sum[min]>temp_sum[j])
min = j;
}
//sort数组记录排序的学生信息的下标
sort[i] = min;
temp_sum[min] = temp_sum[max]; //利用临时数组将查找过的学生信息的总成绩设为最大值,排除查找干扰
}
for(i=0; i<n; ++i) //再复制一次临时数组
{
temp_num[i] = num[i];
strcpy(temp_names[i],names[i]);
temp_math[i] = math[i];
temp_english[i] = english[i];
temp_computer[i] = computer[i];
temp_sum[i] = sum[i];
}
for(i=0; i<n; i++) //按照下标对原数组进行修改
{
num[i] = temp_num[sort[i]];
strcpy(names[i],temp_names[sort[i]]);
math[i] = temp_math[sort[i]];
english[i] = temp_english[sort[i]];
computer[i] = temp_computer[sort[i]];
sum[i] = temp_sum[sort[i]];
}
printf("排序完毕,请按菜单键2查看排序结果! ");
return ;
}
//7.按学号修改学生信息
int student_alter_num(int n)
{
int nums;
int result;
printf("请输入待修改的学生学号:");
scanf("%d",&nums);
result= -1;
for (i = 0; i<n; ++i)
{
if (nums == num[i])
{
result = i;
break;
}
}
//最后判断q值
if (result == -1)
{
printf("没有该学生信息! ");
return 0;
}
else //修改信息值
{
printf("请重新输入该学生信息: ");
printf("学号: ");
scanf("%d",&num[result]);
printf("姓名: ");
scanf("%s",names[result]);
printf("数学成绩: ");
scanf("%d",&math[result]);
printf("英语成绩: ");
scanf("%d",&english[result]);
printf("计算机成绩: ");
scanf("%d",&computer[result]);
sum[result] = math[result] + english[result] + computer[result];
}
return 1;
}
//8.按姓名修改学生信息
int student_alter_name(int n)
{
char name[50];
int result;
printf("请输入待修改的学生姓名:");
scanf("%s",name);
result= -1;
for (i = 0; i<n; ++i)
{
if (strcmp(name,names[i])==0)
{
result = i;
break;
}
}
//最后判断q值
if (result == -1)
{
printf("没有该学生信息! ");
return 0;
}
else //修改信息值
{
printf("请重新输入该学生信息: ");
printf("学号: ");
scanf("%d",&num[result]);
printf("姓名: ");
scanf("%s",names[result]);
printf("数学成绩: ");
scanf("%d",&math[result]);
printf("英语成绩: ");
scanf("%d",&english[result]);
printf("计算机成绩: ");
scanf("%d",&computer[result]);
sum[result] = math[result] + english[result] + computer[result];
}
return 1;
}
//9.按学号删除学生信息
int student_delete_num(int n)
{
int nums;
int result;
printf("请输入待删除的学生学号:");
scanf("%d",&nums);
result= -1;
for (i = 0; i<n; ++i)
{
if (nums == num[i])
{
result = i;
break;
}
}
//最后判断q值
if (result == -1)
{
printf("没有该学生信息! ");
return 0;
}
else //删除当前学生信息即为将数组从result的位置依次前挪一个位置
{
for(i=result; i<n-1; ++i) //最后在main函数中,要将n的值减1
{
num[i] = num[i+1];
strcpy(names[i],names[i+1]);
math[i] = math[i+1];
english[i] = english[i+1];
computer[i] = computer[i+1];
sum[i] = sum[i+1];
}
}
return 1;
}
//10.按姓名删除学生信息
int student_delete_name(int n)
{
char name[50];
int result;
printf("请输入待删除的学生姓名:");
scanf("%s",name);
result= -1;
for (i = 0; i<n; ++i)
{
if (strcmp(name,names[i])==0)
{
result = i;
break;
}
}
//最后判断q值
if (result == -1)
{
printf("没有该学生信息! ");
return 0;
}
else //删除当前学生信息即为将数组从result的位置依次前挪一个位置
{
for(i=result; i<n-1; ++i) //最后在main函数中,要将n的值减1
{
num[i] = num[i+1];
strcpy(names[i],names[i+1]);
math[i] = math[i+1];
english[i] = english[i+1];
computer[i] = computer[i+1];
sum[i] = sum[i+1];
}
}
return 1;
}
Ⅹ c语言学生管理系统
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define MAX 1000
/*定义学生成绩信息结构*/
struct stu
{
char id[8];
char name[8];
double Chinese;
double Math;
double English;
double average;
double total;
};
/*学生结构数组,用于存储学生成绩信息*/
struct stu students[MAX];
/*当前学生人数*/
int current;
void input()
{
int i;
printf("请输入学生人数:");
scanf("%d", & current);
for (i = 0; i < current; i++)
{
printf("\n请输入学生学号,最多为7位数: ");
scanf("%s", students[i].id);
printf("请输入学生姓名:");
scanf("%s", students[i].name);
printf("请输入语文成绩:");
scanf("%lf", &students[i].Chinese);
printf("请输入数学成绩:");
scanf("%lf", &students[i].Math);
printf("请输入英语成绩:");
scanf("%lf", &students[i].English);
students[i].total = students[i].Chinese + students[i].Math + students[i].English;
students[i].average = students[i].total / 3;
}
}
/*排名次,即对学生结构数组排序*/
void sort(struct stu array[], int n)
{
int i, j;
struct stu temp;
for (i = 0; i < n; i++)
{
for (j = i+1; j < n; j++)
{
if (array[i].average - array[j].average < 1e-16)
{
temp = array[i];
array[i] = array[j];
array[j] = temp;
}
}
}
}
/*统计平均成绩,并输出各分数段的人数*/
void print_score(struct stu array[], int n)
{
int i;
double ave = 0;
int sum1 = 0, sum2 = 0, sum3 = 0, sum4 = 0;
for (i = 0; i < n; i++)
{
ave += array[i].average;
switch ((int)(array[i].average / 10))
{
case 10:
case 9: sum1++; break;
case 8: sum2++; break;
case 7:
case 6: sum3++; break;
default: sum4++;
}
}
printf("全班的平均分为:%.1f\n", ave/n);
printf("平均分在90分以上的人数为:%d\n", sum1);
printf("平均分在80~89的人数为:%d\n", sum2);
printf("平均分在60~79的人数为:%d\n", sum3);
printf("平均分在60分以下的人数为:%d\n", sum4);
}
/*输出不及格科目及学生名单*/
void print_unreach(struct stu array[], int n)
{
int i;
printf("科目\t学号\t名字\n");
for (i = 0; i < n; i++)
{
if (array[i].Chinese < 60)
{
printf("语文\t%s\t%s\n", array[i].id, array[i].name);
}
if (array[i].Math < 60)
{
printf("数学\t%s\t%s\n", array[i].id, array[i].name);
}
if (array[i].English < 60)
{
printf("英语\t%s\t%s\n", array[i].id, array[i].name);
}
}
}
/*打印优等生名单*/
void print_good(struct stu array[], int n)
{
int i;
char mark = 0;
if (n > 3)
{
n = 3;
}
printf("学号\t姓名\t语文\t数学\t英语\t平均分\t名次\n");
for (i = 0; i < n; i++)
{
if ((array[i].Chinese > 60) && (array[i].Math > 60) && (array[i].English > 60))
{
if (array[i].average > 90) mark = 1;
else if (array[i].average > 85)
{
if (array[i].Chinese == 100) mark = 1;
if (array[i].Math == 100) mark = 1;
if (array[i].English == 100) mark = 1;
if (array[i].Chinese > 95 && array[i].English > 95) mark = 1;
if (array[i].Chinese > 95 && array[i].Math > 95) mark = 1;
if (array[i].Math > 95 && array[i].English > 95) mark = 1;
}
if (mark == 1)
{
printf("%s\t%s\t", array[i].id, array[i].name);
printf("%.f\t%.f\t%.f\t%.1f\t", array[i].Chinese, array[i].Math, array[i].English, array[i].average);
printf("%d\n", i+1);
}
}
}
}
/*按学生姓名查询成绩*/
void search_name(struct stu array[], int n, char* name)
{
int i;
char mark = 1;
for (i = 0; i < n; i++)
{
if (strcmp(name, array[i].name) == 0)
{
printf("学生姓名:%s\n", name);
printf("学生学号:%s\n", array[i].id);
printf("语文:%.f\n", array[i].Chinese);
printf("数学:%.f\n", array[i].Math);
printf("英语:%.f\n", array[i].English);
printf("平均分:%.1f\n", array[i].average);
mark = 0;
}
}
if (mark == 1) puts("不存在该学生记录");
}
/*按学生学号查询成绩*/
void search_id(struct stu array[], int n, char* id)
{
int i;
char mark = 1;
for (i = 0; i < n; i++)
{
if (strcmp(id, array[i].id) == 0)
{
printf("学生姓名:%s\n", array[i].name);
printf("学生学号:%s\n", array[i].id);
printf("语文:%.f\n", array[i].Chinese);
printf("数学:%.f\n", array[i].Math);
printf("英语:%.f\n", array[i].English);
printf("平均分:%.1f\n", array[i].average);
mark = 0;
break;
}
}
if (mark == 1) puts("不存在该学生记录");
}
void print_menu()
{
system("cls");
printf("1.输入学生信息\n");
puts("2.统计全班学生成绩");
puts("3.按学号查询学生成绩");
puts("4.按姓名查询学生成绩");
puts("5.输出不及格情况");
puts("6.输出优等生名单");
puts("0.退出本程序");
printf("\n\n 请输入你的选择:");
}
int main(int argc, char **argv)
{
char ch = 0;
char id[8], name[8];
while (ch != '0')
{
print_menu();
ch = getchar();
switch (ch)
{
case '1':
{
system("cls");
input();
sort(students, current);
break;
}
case '2':
{
system("cls");
print_score(students, current);
break;
}
case '3':
{
system("cls");
printf("请输入学号:");
scanf("%s", id);
search_id(students, current, id);
break;
}
case '4':
{
system("cls");
printf("请输入姓名:");
scanf("%s", name);
search_name(students, current, name);
break;
}
case '5':
{
system("cls");
print_unreach(students, current);
break;
}
case '6':
{
system("cls");
print_good(students, current);
break;
}
case '0': exit(0);
}
printf("\n\n按任意键返回主菜单……");
getchar();
getchar();
}
return 0;
}