基于C語(yǔ)言實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)
本文實(shí)例為大家分享了C語(yǔ)言實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)的具體代碼,供大家參考,具體內(nèi)容如下
這里只貼代碼,具體介紹省略。
#include <stdio.h>
#include <io.h>
#include <conio.h>
#include <stdlib.h>
#include <string.h>
#define MAX 200
struct student
{
char no[10]; // 學(xué)號(hào)
char name[50]; // 姓名
float score[3]; // 分?jǐn)?shù)
float math;
float eng;
float phy;
};
struct data
{
int count; // 當(dāng)前學(xué)生數(shù)組中學(xué)生的個(gè)數(shù)
struct student stu[MAX]; // 學(xué)生數(shù)組
}dd;
// 顯示主菜單
void menu()
{
system("cls");//清屏
printf("\n\n\n");
printf("\t\t\t *******************************\n");
printf("\t\t\t \n");
printf("\t\t\t 學(xué)生成績(jī)管理系統(tǒng) \n");
printf("\t\t\t \n");
printf("\t\t\t [1] 查看所有學(xué)生信息 \n");
printf("\t\t\t [2] 輸入學(xué)生記錄 \n");
printf("\t\t\t [3] 刪除學(xué)生記錄 \n");
printf("\t\t\t [4] 修改學(xué)生記錄 \n");
printf("\t\t\t [5] 查詢學(xué)生成績(jī)(學(xué)號(hào)) \n");
printf("\t\t\t [6] 查詢成學(xué)生績(jī)(姓名) \n");
printf("\t\t\t [7] 查看成績(jī)排序(學(xué)號(hào)) \n");
printf("\t\t\t [0] 退出 \n");
printf("\t\t\t \n");
}
// 等待用戶按回車(chē)后回到主菜單
void to_menu()
{
char c1,c2;
printf("\n\n\n按回車(chē)鍵返回主菜單...");
scanf("%c%c",&c1,&c2);//第一個(gè)字符吸收上次的確認(rèn)回車(chē)鍵
menu();
}
//統(tǒng)計(jì)信息
void ren()
{
int A=0,B=0,C=0,D=0,E=0,s;
int i;
for(i=0;i<dd.count;i++)
{
s=(int)(dd.stu[i].math/10);
switch(s)
{
case 10:
case 9:
A++;
break;
case 8:
B++;
break;
case 7:
C++;
break;
case 6:
D++;
break;
default :
E++;
break;
}
}
printf("總?cè)藬?shù):%d\n",dd.count);
printf("獲得“優(yōu)秀”的人數(shù):%d\n",A);
printf("獲得“良”的人數(shù):%d\n",B);
printf("獲得“中”的人數(shù):%d\n",C);
printf("獲得“及格”的人數(shù):%d\n",D);
printf("不及格的人數(shù):%d\n",E);
}
// 查看所有學(xué)生信息
void view_data()
{
int i;
printf("學(xué)號(hào)\t姓名\t數(shù)學(xué)\t英語(yǔ)\t物理");
printf("\n-------------------------------------------------------------------\n");
for(i=0;i<dd.count;i++)
printf("%s\t%s\t%-7.1f\t%-7.1f\t%-7.1f\n",dd.stu[i].no,dd.stu[i].name,dd.stu[i].math,dd.stu[i].eng,dd.stu[i].phy);
printf("\n-------------------------------------------------------------------\n");
ren();
}
// 將數(shù)據(jù)從結(jié)構(gòu)體數(shù)組保存到文件中
void save_data()
{
FILE *fp;//文件指針
int i,k;
k = dd.count; //其實(shí)k沒(méi)有什么實(shí)際的意義,直接在fwrite里使用&dd.count就可以了。
fp=fopen("D:\\data.txt","w");//文件存儲(chǔ)位置:當(dāng)前文件夾
fwrite(&k,sizeof(int),1,fp);
for(i=0;i<dd.count;i++)
fwrite(&dd.stu[i],sizeof(struct student),1,fp);
fclose(fp);
}
// 輸入學(xué)生記錄
void add_data()
{
int b;
int k = dd.count;
while(k<MAX)
{
printf("請(qǐng)輸入學(xué)生學(xué)號(hào):"); scanf("%s",dd.stu[k].no);
printf("請(qǐng)輸入學(xué)生姓名:"); scanf("%s",dd.stu[k].name);
printf("請(qǐng)輸入數(shù)學(xué)成績(jī):"); scanf("%f",&dd.stu[k].math);
printf("請(qǐng)輸入英語(yǔ)成績(jī):"); scanf("%f",&dd.stu[k].eng);
printf("請(qǐng)輸入物理成績(jī):"); scanf("%f",&dd.stu[k].phy);
dd.count++; //需要提前置0,在主函數(shù)中。
k = dd.count;
printf("\n\n繼續(xù)添加學(xué)生信息[1-yes 0-no]:");
scanf("%d",&b);
if(b==0) break;
}
save_data();
}
// 將數(shù)據(jù)從文件讀到結(jié)構(gòu)體數(shù)組中
void read_data()
{
FILE *fp;
int i,k;
k=0;
if((fp=fopen("D:\\data.txt","r"))==NULL) // 如果文件不存在
{
dd.count = 0;
}
else
{
fread(&k,sizeof(int),1,fp);
dd.count = k;
for(i=0;i<k;i++)
{
fread(&dd.stu[i],sizeof(struct student),1,fp);
}
fclose(fp);
}
}
// 刪除學(xué)生記錄
void delete_data()
{
int i,k;
char no[10];
printf("\n請(qǐng)輸入要?jiǎng)h除學(xué)生的學(xué)號(hào):");
scanf("%s",no);
k = -1;
for(i=0;i<dd.count;i++)
{
if(strcmp(dd.stu[i].no,no)==0)
{
k = i;
break;
}
}
if(k==-1)
{
printf("\n\n沒(méi)有找到該學(xué)生(學(xué)號(hào)-%s)!",no);
}
else
{
//你沒(méi)有寫(xiě)刪除的操作啊
for(i=k; i<dd.count-1; i++) //將后面的數(shù)據(jù)前移一位
dd.stu[i] = dd.stu[i+1];
memset(&dd.stu[dd.count-1],0,sizeof(struct student)); //將dd.stu[dd.count-1]數(shù)據(jù)置0
dd.count--;
save_data();
printf("\n\n刪除學(xué)生(學(xué)號(hào)-%s)記錄成功!",no);
}
}
// 修改學(xué)生記錄
void edit_data()
{
int i,k;
char no[10],name[50];
printf("\n請(qǐng)輸入要修改學(xué)生的學(xué)號(hào):");
scanf("%s",no);
k=-1;
for(i=0;i<dd.count;i++)
{
if(strcmp(dd.stu[i].no,no)==0)
{
k=i;
break;
}
}
if(k==-1)
{
printf("\n\n沒(méi)有找到該學(xué)生(學(xué)號(hào)-%s)!",no);
}
else
{
printf("\n請(qǐng)輸入學(xué)生數(shù)據(jù):");
printf("\n姓名");
printf("\n--------------------------------------------------------------------\n");
scanf("%s",name);
strcpy(dd.stu[k].name,name);
save_data();
printf("\n\n修改學(xué)生記錄(學(xué)號(hào)-%s)成功!",no);
}
}
// 查詢學(xué)生成績(jī)(學(xué)號(hào))
void query_data_no()
{
int i,k;
char no[10];
printf("\n請(qǐng)輸入要查詢學(xué)生的學(xué)號(hào):");
scanf("%s",no);
k=-1;
for(i=0;i<dd.count;i++)
{
if(strcmp(dd.stu[i].no,no)==0)
{
printf("\n\n學(xué)號(hào)\t姓名\t數(shù)學(xué)\t英語(yǔ)\t物理");
printf("\n-----------------------------------------------------------------\n");
k=i;
printf("%s\t%s\t%-7.1f\t%-7.1f\t%-7.1f\n",dd.stu[i].no,dd.stu[i].name,dd.stu[i].math,dd.stu[i].eng,dd.stu[i].phy);
break; // 學(xué)號(hào)應(yīng)該是唯一的,找到了一個(gè)就代表以后的沒(méi)有了。
}
}
if(k==-1)
{
printf("\n\n沒(méi)有找到該學(xué)生(學(xué)號(hào)-%s)!",no);
}
}
// 查詢學(xué)生成績(jī)(姓名)
void query_data_name()
{
int i,k;
char name[10];
printf("\n請(qǐng)輸入要查詢學(xué)生的姓名:");
scanf("%s",name);
k=-1;
for(i=0;i<dd.count;i++)
{
if(strcmp(dd.stu[i].name,name)==0)
{
printf("\n\n學(xué)號(hào)\t姓名\t數(shù)學(xué)\t英語(yǔ)\t物理");
printf("\n-----------------------------------------------------------------\n");
k=i;
printf("%s\t%s\t%-7.1f\t%-7.1f\t%-7.1f\n",dd.stu[i].no,dd.stu[i].name,dd.stu[i].math,dd.stu[i].eng,dd.stu[i].phy);
break;
}
}
if(k==-1)
{
printf("\n\n沒(méi)有找到該學(xué)生(姓名-%s)!",name);
}
}
// 排序(學(xué)號(hào))
void sort_data_no(struct data Buff)
{
int i;
int j;
int k;
int h;
struct student temp;
FILE *fp;
if((fp=fopen("D:\\data.txt","w+"))==NULL)
{
printf("cannot open file!\n");
exit(0);
}
printf("請(qǐng)輸入要查詢的科目:1-數(shù)學(xué),2-英語(yǔ),3-物理:");
scanf("%d",&k);
switch(k)
{
case 1:
for(i=0; i<Buff.count-1; i++)
for(j=i+1; j<Buff.count; j++)
if(Buff.stu[i].math > Buff.stu[j].math)
{
temp=Buff.stu[i];
Buff.stu[i]=Buff.stu[j];
Buff.stu[j]=temp;
}
printf("名次\t學(xué)號(hào)\t 姓名\t數(shù)學(xué)\n");
for(i=0; i<Buff.count; i++)
printf("%d\t%s\t%s\t%-7.1f\n",i+1,Buff.stu[i].no,Buff.stu[i].name,Buff.stu[i].math);
break;
case 2:
for(i=0; i<Buff.count-1; i++)
for(j=i+1; j<Buff.count; j++)
if(Buff.stu[i].eng > Buff.stu[j].eng)
{
temp=Buff.stu[i];
Buff.stu[i]=Buff.stu[j];
Buff.stu[j]=temp;
}
printf("名次\t學(xué)號(hào)\t 姓名\t英語(yǔ)\n");
for(i=0; i<Buff.count; i++)
printf("%d\t%s\t%s\t%-7.1f\n",i+1,Buff.stu[i].no,Buff.stu[i].name,Buff.stu[i].eng);
break;
case 3:
for(i=0; i<Buff.count-1; i++)
for(j=i+1; j<Buff.count; j++)
if(Buff.stu[i].phy > Buff.stu[j].phy)
{
temp=Buff.stu[i];
Buff.stu[i]=Buff.stu[j];
Buff.stu[j]=temp;
}
printf("名次\t學(xué)號(hào)\t 姓名\t物理\n");
for(i=0; i<Buff.count; i++)
printf("%d\t%s\t%s\t%-7.1f\n",i+1,Buff.stu[i].no,Buff.stu[i].name,Buff.stu[i].phy);
break;
default :
printf("輸入錯(cuò)誤!");
exit(0);
}
printf("請(qǐng)按任意鍵繼續(xù)....");
getch();
fclose(fp);
}
// 主函數(shù)
int main(void)
{
int fun;
dd.count = 0;
read_data();
menu();
while(1)
{
printf("請(qǐng)輸入功能號(hào)[0-7]:");//這里不需要什么&fun,
scanf("%d",&fun);
switch(fun)
{
case 1: view_data();break; // 查看所有學(xué)生信息
case 2: add_data(); break; // 輸入學(xué)生記錄
case 3: delete_data();break; // 刪除學(xué)生記錄
case 4: edit_data();break; // 修改學(xué)生記錄
case 5: query_data_no();break; // 查詢學(xué)生成績(jī)(學(xué)號(hào))
case 6: query_data_name();break; // 查詢成學(xué)生績(jī)(姓名)
case 7: sort_data_no(dd); break; // 查看成績(jī)排序(學(xué)號(hào)) //直接將結(jié)構(gòu)體dd發(fā)送過(guò)去就可以了
case 0: break; // 退出
}
if(fun==0) break;
to_menu();
}
return 0;
}
更多學(xué)習(xí)資料請(qǐng)關(guān)注專題《管理系統(tǒng)開(kāi)發(fā)》。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- C語(yǔ)言學(xué)生成績(jī)管理系統(tǒng)源代碼
- C語(yǔ)言版學(xué)生成績(jī)管理系統(tǒng)
- C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單學(xué)生成績(jī)管理系統(tǒng)
- C語(yǔ)言利用結(jié)構(gòu)體數(shù)組實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)
- C語(yǔ)言學(xué)生成績(jī)管理系統(tǒng)設(shè)計(jì)
- C語(yǔ)言學(xué)生成績(jī)管理系統(tǒng)小設(shè)計(jì)
- C語(yǔ)言實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)實(shí)戰(zhàn)教學(xué)
相關(guān)文章
MATLAB中subplot函數(shù)的語(yǔ)法與使用實(shí)例
subplot()是將多個(gè)圖畫(huà)到一個(gè)平面上的工具,下面這篇文章主要給大家介紹了關(guān)于MATLAB中subplot函數(shù)的語(yǔ)法與使用的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08
C++各種數(shù)據(jù)類型所占內(nèi)存大小詳解
這篇文章主要介紹了C++各種數(shù)據(jù)類型所占內(nèi)存大小,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08
C語(yǔ)言 structural body結(jié)構(gòu)體詳解用法
C 數(shù)組允許定義可存儲(chǔ)相同類型數(shù)據(jù)項(xiàng)的變量,結(jié)構(gòu)是 C 編程中另一種用戶自定義的可用的數(shù)據(jù)類型,它允許您存儲(chǔ)不同類型的數(shù)據(jù)項(xiàng),結(jié)構(gòu)用于表示一條記錄,假設(shè)您想要跟蹤圖書(shū)館中書(shū)本的動(dòng)態(tài),您可能需要跟蹤每本書(shū)的下列屬性2021-10-10
linux下C/C++學(xué)生信息管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了linux下c/c++學(xué)生信息管理系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01
詳解C++ 多態(tài)的兩種形式(靜態(tài)、動(dòng)態(tài))
這篇文章主要介紹了C++ 多態(tài)的兩種形式,幫助大家更好的理解和學(xué)習(xí)c++,感興趣的朋友可以了解下2020-08-08
C++數(shù)據(jù)結(jié)構(gòu)與算法之哈夫曼樹(shù)的實(shí)現(xiàn)方法
這篇文章主要介紹了C++數(shù)據(jù)結(jié)構(gòu)與算法之哈夫曼樹(shù)的實(shí)現(xiàn)方法,簡(jiǎn)單說(shuō)明了哈夫曼樹(shù)的原理,并結(jié)合具體實(shí)例形式分析了C++實(shí)現(xiàn)哈夫曼樹(shù)的相關(guān)操作技巧,需要的朋友可以參考下2017-11-11
C語(yǔ)言 strftime 格式化顯示日期時(shí)間的實(shí)現(xiàn)
下面小編就為大家?guī)?lái)一篇C語(yǔ)言 strftime 格式化顯示日期時(shí)間的實(shí)現(xiàn)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-12-12
C++設(shè)置超時(shí)時(shí)間的簡(jiǎn)單實(shí)現(xiàn)方法
這篇文章主要介紹了C++設(shè)置超時(shí)時(shí)間的簡(jiǎn)單實(shí)現(xiàn)方法,涉及系統(tǒng)函數(shù)setsockopt對(duì)套接口的操作,具有一定的實(shí)用價(jià)值,需要的朋友可以參考下2014-10-10

