我来教大家“麻将神器排行榜最新版本”(确实是有挂)-哔哩哔哩

网上有关“用C语言编写一个学生管理系统。”话题很是火热,小编也是针对用C语言编写一个学生管理系统。寻找了一些与之相关的一些信息进行分析,如果能碰巧解决你现在面临的问题,希望能够帮助到您。

您好:手机麻将有挂是真的吗这款游戏可以开挂,确实是有挂的,咨询加微信【】很多玩家在这款游戏中打牌都会发现很多用户的牌特别好,总是好牌,而且好像能看到其他人的牌一样。所以很多小伙伴就怀疑这款游戏是不是有挂,实际上这款游戏确实是有挂的
http://www.boyicom.net/sheng/1.jpg
1.手机麻将有挂是真的吗这款游戏可以开挂,确实是有挂的,通过添加客服微信 2.咨询软件加微信【】在"设置DD功能DD微信手麻工具"里.点击"开启". 3.打开工具.在"设置DD新消息提醒"里.前两个选项"设置"和"连接软件"均勾选"开启"(好多人就是这一步忘记做了) 4.打开某一个微信组.点击右上角.往下拉."消息免打扰"选项.勾选"关闭"(也就是要把"群消息的提示保持在开启"的状态.这样才能触系统发底层接口)

概述

单纯只用多个数组管理学生成绩信息,不使用结构体,该程序最主要的难点是依据学号或总成绩对学生信息进行排序,借助了临时数组来标记排好序的下标。

运行结果如下:

输入数据:?

根据总成绩排序:

根据学号删除学生信息:

贴上代码(有点多)

#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("*************************************\n");

printf("欢迎使用学生成绩管理系统\n");

printf("[1] 输入所有学生信息\n");

printf("[2] 输出所有学生成绩\n");

printf("[3] 按学号查找某个学生信息\n");

printf("[4] 按姓名查找某个学生信息\n");

printf("[5] 按学号对学生排序\n");

printf("[6] 按总成绩对学生排序\n");

printf("[7] 按学号修改某个学生信息\n");

printf("[8] 按姓名修改某个学生信息\n");

printf("[9] 按学号删除某个学生信息\n");

printf("[10] 按姓名删除某个学生信息\n");

printf("[0] 退出程序\n");

printf("请输入您的选择(0 - 9):");

scanf("%d",&choice);

printf("**************************************)\n");

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("退出程序\n");

printf("程序结束,谢谢使用!\n");

exit(0);

default:

printf("您输入的菜单有误。请重新输入!\n");

}

}

return 0;

}

//1.输入信息

void student_scanf(int n)

{

for (i = 0; i<n; ++i)

{

printf("\n请输入第%d个学生的信息:\n", i + 1);

printf("\n学号:");

scanf("%d", &num[i]);

printf("\n姓名:");

scanf("%s", names[i]);

printf("\n数学成绩:");

scanf("%d", &math[i]);

printf("\n英语成绩:");

scanf("%d", &english[i]);

printf("\n计算机成绩:");

scanf("%d", &computer[i]);

//计算总成绩

sum[i] = math[i] + english[i] + computer[i];

}

}

//2.打印信息 ?

void student_printf(int n)

{

printf("\n学号\t姓名\t数学成绩\t英语成绩\t计算机成绩\t总成绩\n");

printf("----------------------------------------------------------\n");

for (i = 0; i<n; ++i)

{

printf("%d\t%s\t%d\t\t%d\t\t%d\t\t%d\n", num[i], names[i], math[i], english[i], computer[i], sum[i]);

}

printf("-------------------------------------------------------\n");

}

//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("没有该学生信息!\n");

return 0;

}

else

{

//先打印表头

printf("\n学号\t\t姓名\t\t数学成绩\t英语成绩\t计算机成绩\t总成绩\n");

//再打印数据

printf("%d\t\t%s\t\t%d\t\t%d\t\t%d\t%d\n", num[result], names[result], math[result], english[result], computer[result], sum[result]);

printf("打印出查找结果!\n");

}

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("没有该学生信息!\n");

return 0;

}

else//找到结果

{

printf("\n学号\t姓名\t数学成绩\t英语成绩\t计算机成绩\t总成绩\n");

printf("%d\t%s\t%d\t\t%d\t\t%d\t\t%d\n", num[result], names[result], math[result], english[result], computer[result], sum[result]);

printf("已完成查找!\n");

}

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查看排序结果!\n");

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查看排序结果!\n");

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("没有该学生信息!\n");

return 0;

}

else //修改信息值?

{

printf("请重新输入该学生信息:\n");

printf("学号:\n");

scanf("%d",&num[result]);

printf("姓名:\n");

scanf("%s",names[result]);?

printf("数学成绩:\n");

scanf("%d",&math[result]);

printf("英语成绩:\n");

scanf("%d",&english[result]);

printf("计算机成绩:\n");

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("没有该学生信息!\n");

return 0;

}

else //修改信息值?

{

printf("请重新输入该学生信息:\n");

printf("学号:\n");

scanf("%d",&num[result]);

printf("姓名:\n");

scanf("%s",names[result]);?

printf("数学成绩:\n");

scanf("%d",&math[result]);

printf("英语成绩:\n");

scanf("%d",&english[result]);

printf("计算机成绩:\n");

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("没有该学生信息!\n");

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("没有该学生信息!\n");

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语言课程设计之学生成绩管理系统设计的程序

可以实现定义输入N个人M门科目的成绩输入,有查找、排序功能

#include <stdio.h>

#include <string.h>

#define NUM 100

struct student

{

int number; //学号

char name[12]; //姓名

int score[20]; //成绩

int total; //总分

double average; //平均分

};

struct student stu[NUM];

int c=0; //c是结构体数组的下标 在此为全局变量

int d=0; //d是结构体数组的下标 在此为全局变量

void menu(); //定义menu菜单

void input(); //插入数据函数

void sort(); //排序

void find(); //查找(按学号或姓名查找

void error(); //错误提示

void print(); //输出具体信息

void main()

{

menu();

}

void menu()//主菜单

{

int select; //选择(1--5间)

system("cls");

printf(" ☆ ★*☆ ★*☆ ★*☆★*☆ ★*☆★ \n");

printf(" ★*☆★ ◢█◣★*☆★*☆  \n");

printf(" ★*☆★*★  ◢███◣ ★*☆★*★☆  \n");

printf(" ★*☆ ★*☆ ★ .█████.★*☆ ★*☆ ★ \n");

printf(" ★*☆ ★*☆*★★.█田█田█.★*☆ ★*☆ ★★ \n");

printf(" ★*☆ ★*☆*★★.█田█田█.★*☆ ★*☆ ★★ \n");

printf(" ★*☆ ★*☆*★★.█田█田█.★*☆ ★*☆ ★★ \n");

printf(" ★*☆ ★*☆*★★.█田█田█.★*☆ ★*☆ ★★ \n");

printf(" ★*☆ ★*☆*★★.█田█田█.★*☆ ★*☆ ★★ \n");

printf(" ★*☆ ★*☆*★★.█田█田█.★*☆ ★*☆*★★ \n");

printf(" ★*☆ ★*☆*★★.█田█田█.★*☆ ★*☆ ★★ \n");

printf(" ★*☆ ★*☆*★★.█████.★*☆ ★*☆*★★ \n");

printf(" ★*☆ ★*☆*★★.█████.★*☆ ★*☆ ★★ \n");

printf(" ~~~~~*^_^* ◢██□██◣.*^_^* ~~~~~ \n\n");

printf(" 学生成绩管理系统\n");

printf(" ***************\n");

printf(" * *\n");

printf(" *[1]输入数据 *\n");

printf(" *[2]查找数据 *\n");

printf(" *[3]打印输出 *\n");

printf(" *[4]数据排序 *\n");

printf(" *[5]退出 *\n");

printf(" * *\n");

printf(" ***************\n");

printf("请输入你的选项(1--5):");

scanf("%d",&select);//输入要选择的项目

switch(select) //判断选择

{

case 1:input();break;

case 2:find();break;

case 3:print();break;

case 4:sort();break;

case 5:exit(0);break;

default:error();break;

}

}

void input() //输入入数据

{

int m,n,i;//m,n,i,j为循环变量

printf("请输入要统计的人数 M= ");

scanf("%d",&c);

printf("请输入要统计的科目数量N= ");

scanf("%d",&d);

printf("\n");

for(m=0;m<c;m++)

{

printf("请输入第%d个学生的学号 \t\t",m+1);

scanf("%d",&stu[m].number);

for (i=0;i<m;i++)

{

if (stu[m].number==stu[i].number)

{

printf("输入的学号重复请重新输入 \t\t");

scanf("%d",&stu[m].number);

}

}

printf("请输入第%d个学生的姓名 \t\t",m+1);

scanf("%s",&stu[m].name);

for (n=0;n<d;n++)

{

printf("请输入第个%d学生的第%d门科目的成绩\t",m+1,n+1);

scanf("%d",&stu[m].score[n]);

stu[m].total+=stu[m].score[n];

}

printf("总分:%d\t",stu[m].total);

stu[m].average=stu[m].total/(d+0.0);

printf("平均分%4.2f\n",stu[m].average);

}

printf("\n按回车键返回主菜单……\n");

getchar();

getchar();

menu();

}

void sort()//排序

{

int i,j;

printf("正在排序中.......\n");

for(i=0;i<c;i++)

{

for(j=i+1;j<=c;j++)

{

if(stu[i].total<stu[j].total)

{

stu[100]=stu[i];

stu[i]=stu[j];

stu[j]=stu[100];

}

}

}

printf("已排好序,请按回车键返回主菜单……\n");

getchar();

getchar();

menu();

}

void find() //查找

{

int stuNO; //学号

char name[12]; //姓名

int flag; //选择标志

int i,j; //循环变量

system("cls"); //清屏

printf("按学号查找[1]:\n");

printf("按姓名查找[2]:\n");

printf("请选择:");

scanf("%d",&flag);

if(flag==1)

{

printf("请输入你要查找的学号:");

scanf("%d",&stuNO);

for(i=0;i<c;i++)

{

if(stu[i].number==stuNO)

{

printf("\n==**==**==** %s的成绩 **==**==**==**==**\n",stu[i].name);

printf("学号:%d\t \n",stu[i].number);

for (j=0;j<d;j++)

{

printf("成绩%d:%d\n",j+1,stu[i].score[j]);

}

printf("总分:%d\t平均分:%4.2f\n",stu[i].total,stu[i].average);

}

}

}

else if(flag==2)

{

printf("请输入你要查找的姓名:");

scanf("%s",name);

for(i=0;i<c;i++)

{

if(strcmp(stu[i].name,name)==0)

{

printf("\n==**==**==** %s的成绩 **==**==**==**==**\n",stu[i].name);

printf("学号:%d\t ",stu[i].number);

for (j=0;j<d;j++)

{

printf("成绩%d:%d\n",j+1,stu[i].score[j]);

}

printf("总分:%d\t平均分:%4.2f\n",stu[i].total,stu[i].average);

}

}

}

else

{

printf("选择的范围(1或2),请重新输入……");

find();

}

printf("\n按回车键返回主菜单……\n");

getchar();

getchar();

menu();

}

void error()

{

system("cls"); //清屏

printf("输入有误,选择的范围是1--7:\n");

printf("\n按回车键继续……\n");

getchar();

getchar();

system("cls"); //清屏

menu();

}

void print() //打印学生成绩信息

{

int i,j;

printf("学号\t姓名\t");

for(j=0;j<d;j++)

{

printf("成绩%d\t",j+1);

}

printf(" 总分\t平均分");

printf("\n");

for(i=0;i<c;i++)

{

printf("%d\t%s\t",stu[i].number,stu[i].name);

for(j=0;j<d;j++)

{

printf("%d\t ",stu[i].score[j]);

}

printf(" %d\t%4.2f\n",stu[i].total,stu[i].average);

}

getchar();

getchar();

menu();

}

#include<stdio.h>

#include<conio.h>

#include <stdlib.h>

#include<string.h>

#define MAX 80

#define max 3

int nu=0;

struct classname

{

char name[20];

float score;

};

struct student

{

char no[20];

char std_name[20];

struct classname km[max];

float ave;

float sum;

int save;

};

struct student stu[MAX],*p;

void chushi()

{

int i,j;

for(i=0;i<MAX;i++)

{

for(j=0;j<20;j++)

{

stu[i].no[j]=NULL;

stu[i].std_name[j]=NULL;

stu[i].km[j].name[j]=NULL;

stu[i].km[j].score=0;

}

stu[i].ave=0;

stu[i].sum=0;

stu[i].save=0;

}

}

void av()/*求平均值*/

{

int i;

for(i=0;i<nu;i++)

{

stu[i].sum=stu[i].km[1].score+stu[i].km[2].score+stu[i].km[3].score;

stu[i].ave=stu[i].sum/3;

}

}

void first_check()

{

FILE *p;

int i,j;

struct classname frist[max];

for(i=0;i<max;i++)

{

for(j=0;j<20;j++)

frist[i].name[j]=NULL;

frist[i].score=0;

}

if ((p=fopen("c:\\kemu.txt","r"))==NULL)

{

printf("您好,欢迎使用学生成绩管理系统\n\n因为您是第一次使用,请输入科目名称(三科)\n\n");

p=fopen("c:\\kemu.txt","w");

printf("输入课程1名称:");

scanf("%s",frist[0].name);

fprintf(p,"%s\n",frist[0].name);

printf("输入课程2名称:");

scanf("%s",frist[1].name);

fprintf(p,"%s\n",frist[1].name);

printf("输入课程3名称:");

scanf("%s",frist[2].name);

fprintf(p,"%s\n",frist[2].name);

}

system("cls");

fclose(p);

}

void save_nu()

{

FILE *p;

p=fopen("c:\\renshu.txt","w");

fprintf(p,"%d\n",nu);

fclose(p);

}

void Save_add(int n)

{

FILE * p;

int i;

p= fopen("c:\\cheji.txt","at");

if (p == NULL)

{

printf("文件不存在!!\n");

exit(0);

}

save_nu();

for (i = 0;i<n;i++)

if(stu[i].save==1)

{

stu[i].sum=stu[i].km[1].score+stu[i].km[2].score+stu[i].km[3].score;

stu[i].ave=stu[i].sum/3;

fprintf(p,"%s %s %2.1f %2.1f %2.1f %2.1f %2.1f \n",stu[i].no,stu[i].std_name,stu[i].km[0].score,stu[i].km[1].score,stu[i].km[2].score,stu[i].ave,stu[i].sum);

}

fclose(p);

}

void Save()

{

FILE * p;

int i;

p= fopen("c:\\cheji.txt","w");

if (p == NULL)

{

printf("文件不存在!!\n");

exit(0);

}

save_nu();

for (i = 0;i<nu;i++)

if(stu[i].save==1)

{

av();

fprintf(p,"%s %s %2.1f %2.1f %2.1f %2.1f %2.1f \n",stu[i].no,stu[i].std_name,stu[i].km[0].score,stu[i].km[1].score,stu[i].km[2].score,stu[i].ave,stu[i].sum);

}

fclose(p);

}

int read_nu()

{

FILE *p;

char ch,s[10]={'\0'};

int i=0;

p=fopen("c:\\renshu.txt","r");

if(p==NULL)

{

save_nu();

return 0;

}

ch=fgetc(p);

while(ch!='\n')

{

s[i]=ch;

ch=fgetc(p);

i++;

}

nu=atoi(s);

fclose(p);

return 0;

}

int read_km()

{

FILE *p;

int i,j=0;

char s[20]={'\0'};

chushi();

p=fopen("c:\\kemu.txt","r");

if(p==NULL)

{

printf("ERROR read_km");

return 0;

}

fgets(s,20,p);

while(strlen(s)!=0)

{

for(i=0;i<strlen(s);i++)

if(s[i]==10)

{

s[i]='\0';

break;

}

for(i=0;i<=nu;i++)

strcpy(stu[i].km[j].name,s);

for(i=0;i<20;i++)

s[i]='\0';

j++;

fgets(s,20,p);

}

}

void read()

{

FILE *p;

int i,j,n,k,z=0;

char s[50]={'\0'};

char o[10]={'\0'};

p=fopen("c:\\cheji.txt","r");

if(p==NULL)

printf("ERROR_read");

chushi();

read_km();

fgets(s,50,p);

while(strlen(s)!=0)

{

j=0;

for(i=0;i<50;i++)

{

if(s[i]!='\n')

{

n=0;

while(j==0)

{

if(s[i]!=' ')

{

stu[z].no[n]=s[i];

n++;i++;

}

else

break;

}

while(j==1)

{

if(s[i]!=' ')

{

stu[z].std_name[n]=s[i];

n++;i++;

}

else

break;

}

while(j==2)

{

if(s[i]!=' ')

{

o[n]=s[i];

n++;i++;

}

else

{

stu[z].km[0].score=atoi(o);

break;

}

}

while(j==3)

{

if(s[i]!=' ')

{

o[n]=s[i];

n++;i++;

}

else

{

stu[z].km[1].score=atoi(o);

break;

}

}

while(j==4)

{

if(s[i]!=' ')

{

o[n]=s[i];

n++;i++;

}

else

{

stu[z].km[2].score=atoi(o);

break;

}

}

while(j==5)

{

if(s[i]!=' ')

{

o[n]=s[i];

n++;i++;

}

else

{

stu[z].ave=atoi(o);

break;

}

}

while(j==6)

{

if(s[i]!=' ')

{

o[n]=s[i];

n++;i++;

}

else

{

stu[z].sum=atoi(o);

break;

}

}

for(k=0;k<10;k++)

o[k]='\0';

}

else

break;

j++;

}

for(i=0;i<50;i++)

s[i]='\0';

fgets(s,50,p);

z++;

}

}

void putin()

{

int n,i=0;

char ch;

read_km();

do

{

printf("\t\t\t\t录入学员信息\n输入第%d个学员的信息\n",i+1);

printf("\n输入学生编号:");

scanf("%s",stu[i].no);

printf("\n输入学员姓名:");

scanf("%s",stu[i].std_name);

printf("\n输入课程%s的分数:",stu[0].km[0].name);

scanf("%f",&stu[i].km[0].score);

printf("\n输入课程%s的分数:",stu[0].km[1].name);

scanf("%f",&stu[i].km[1].score);

printf("\n输入课程%s的分数:",stu[0].km[2].name);

scanf("%f",&stu[i].km[2].score);

stu[i].save=1;

printf("\n\n");

i++;

n=i;

printf("是否继续输入?(Y/N)");

fflush(stdin);

ch=getch();

system("cls");

}

while(ch!='n'&&ch!='N');

system("cls");

if(nu==0)

{

nu=n;

Save();

}

else

{

nu=n+nu;

Save_add(n);

}

}

int putout()

{

int i;char s;

if(nu==0)

{

printf("学生信息为零!请录入...");

return 0;

}

read();

do

{

printf("学生成绩信息:\n\n");

for(i=0;i<nu;i++)

printf("学号:%s 姓名:%s\n%s分数:%2.1f\t%s分数:%2.1f\t%s分数:%2.1f\n平均分数:%2.1f\t总成绩:%2.1f\n\n",stu[i].no,stu[i].std_name,stu[i].km[0].name,stu[i].km[0].score,stu[i].km[1].name,stu[i].km[1].score,stu[i].km[2].name,stu[i].km[2].score,stu[i].ave,stu[i].sum);

printf("\t\t按任意键返回主菜单");

fflush(stdin);

s=getch();

}

while(!s);

system("cls");

}

int sort()/*排序数据函数*/

{

struct student temp;

int i,j;

char s;

if(nu==0)

{

printf("学生信息为零!请录入...");

return 0;

}

chushi();

read();

for(i=1;i<nu;i++)

{

for(j=1;j<=nu-i;j++)

{

if(stu[j-1].ave<stu[j].ave)

{

temp=stu[j];

stu[j]=stu[j-1];

stu[j-1]=temp;

}

}

}

do

{

printf("学生成绩信息:\n\n");

for(i=0;i<nu;i++)

printf("学号:%s 姓名:%s 平均成绩:%2.1f\n\n",stu[i].no,stu[i].std_name,stu[i].ave);

printf("\t\t按任意键返回主菜单");

fflush(stdin);

s=getch();

}

while(!s);

system("cls");

}

void find()/*查询函数*/

{

int j,i=0;

int c=0;

char search[10]={'\0'};

char as;

if(nu==0)

{

printf("学生信息为零!请录入...");

return 0;

}

chushi();

read();

do

{

printf("输入要查询课程名称:");

scanf("%s",search);

for(j=0;j<max;j++)

if(!strcmp(stu[i].km[j].name,search))

{

c=1;

printf("\n该课程不及格学生姓名:\n");

for(i=0;i<nu;i++)

if(stu[i].km[j].score<60)

printf("%s\n",stu[i].std_name);

}

if(c==0)

printf("无此课程!");

printf("\n\t\t按任意键返回主菜单");

fflush(stdin);

as=getch();

}

while(!as);

system("cls");

}

void tongji()

{

int j,m,z,i=0;

char s;

if(nu==0)

{

printf("学生信息为零!请录入...");

return 0;

}

chushi();

read();

for(z=0;z<max;z++)

{

m=stu[i].km[z].score;j=0;

printf("%s 最高分: ",stu[i].km[z].name);

for(i=0;i<nu;i++)

if(m<stu[i].km[z].score)

{

m=stu[i].km[z].score;

j=i;

}

printf("%s\t",stu[j].std_name);

j=0;i=0;m=stu[i].km[z].score;

printf("%s 最低分: ",stu[i].km[z].name);

for(i=0;i<nu;i++)

if(m>stu[i].km[z].score)

{

m=stu[i].km[z].score;

j=i;

}

printf("%s\t",stu[j].std_name);

m=0;j=0;i=0;

printf("%s 平均分: ",stu[i].km[z].name);

for(i=0;i<nu;i++)

m=m+stu[i].km[z].score;

printf("%d\n",m/nu);

m=0;i=0;

printf("%s 分数低于的60人数: ",stu[i].km[z].name);

for(i=0;i<nu;i++)

if(stu[i].km[z].score<60)

m++;

printf("%d\t",m);

m=0;j=0;i=0;

printf("%s 分数高于60的人数: ",stu[i].km[z].name);

for(i=0;i<nu;i++)

if(stu[i].km[z].score>60)

m++;

printf("%d\n\n",m);

}

do

{

printf("\t\t按任意键返回主菜单");

fflush(stdin);

s=getch();

}

while(!s);

system("cls");

}

void main()/*主函数*/

{

int as;

first_check();

start: printf("\n\t\t\t欢迎使用学生成绩管理系统\n");

/*一下为功能选择模块*/

do

{

printf("\n\t\t\t\t1.录入学员信息\n\t\t\t\t2.显示学员信息\n\t\t\t\t3.成绩排序信息\n\t\t\t\t4.查询不及格学生\n\t\t\t\t5.统计信息\n\t\t\t\t6.退出\n");

printf("\t\t\t\t选择功能选项:");

fflush(stdin);

read_nu();

scanf("%d",&as);

switch(as)

{

case 1:system("cls");putin();break;

case 2:system("cls");putout();break;

case 3:system("cls");sort();break;

case 4:system("cls");find();break;

case 5:system("cls");tongji();break;

case 6:system("exit");exit(0);

default:system("cls");goto start;

}

}

while(1);

/*至此功能选择结束*/

}

关于“用C语言编写一个学生管理系统。”这个话题的介绍,今天小编就给大家分享完了,如果对你有所帮助请保持对本站的关注!

(0)
上一篇 2024年05月15日
下一篇 2024年05月15日

相关推荐