C語(yǔ)言學(xué)生成績(jī)管理系統(tǒng)課程設(shè)計(jì)
學(xué)生成績(jī)管理系統(tǒng)是比較適合初學(xué)者的。它涵蓋了c語(yǔ)言幾乎知識(shí)。對(duì)于學(xué)了c語(yǔ)言的人,把這個(gè)課程設(shè)計(jì)搞好(當(dāng)然自己能設(shè)計(jì)出來(lái)是要有很好的基礎(chǔ))。不管自己能不能夠完成,最重要的是能弄懂。參考其他資料,試著自己編寫(xiě)是不錯(cuò)的選擇。這個(gè)課程設(shè)計(jì)也是我參照資料,自己編寫(xiě)的。自己適當(dāng)?shù)卦黾恿艘恍┕δ堋2贿^(guò),編的不夠那么專業(yè)吧。
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#define size 100
char* classname[]={"語(yǔ)文","數(shù)學(xué)","英語(yǔ)"};
int N=0,falg=0; //定義全局變量 N代表人數(shù),falg代表信息保存的標(biāo)識(shí)。
int arrysize=size; //arrysize代表結(jié)構(gòu)體數(shù)組的大小。
struct stu{
char num[10];
char name[10];
float score[3];
float sum;
};
typedef struct stu STU; //定義新類型的結(jié)構(gòu)體。
STU*pro=NULL; // pro保存信息的結(jié)構(gòu)體數(shù)組。
int chack(int a,int b,int c) //條件判斷函數(shù),c代表?xiàng)l件號(hào)。
{
if(c==1||c==2)
{
if(pro[a].sum !=pro[b].sum )
if(c==1)
return pro[a].sum >pro[b].sum ;
else
return pro[a].sum <pro[b].sum;
else return strcmp(pro[a].num ,pro[b].num)<0;
}
if(c==3||c==4)
{
if(c==3) return strcmp(pro[a].num,pro[b].num )<0;
else return strcmp(pro[a].num,pro[b].num )>0;
}
else printf("沒(méi)有該條件的選項(xiàng)!\n");
return 0;
}
void incharge(int a,int b) //交換函數(shù)。
{
struct stu t;
t=pro[a];
pro[a]=pro[b];
pro[b]=t;
}
void het(int m,int n,int c) //快排函數(shù)
{ if(m>n) return;
int i=m-1;
for(int j=m;j<n;j++)
{
if(chack(j,n,c))
incharge(++i,j);
}
incharge(i+1,n);
het(1,i,c);
het(i+2,n,c);
}
void newsect(int i) //添加記錄函數(shù)
{ float s=0;
printf("請(qǐng)輸入學(xué)生學(xué)號(hào):");
scanf("%s",&pro[i].num);
printf("請(qǐng)輸入學(xué)生姓名:");
scanf("%s",&pro[i].name);
for(int j=0;j<3;j++)
{
printf("請(qǐng)輸入%s成績(jī):",classname[j]);
scanf("%f",&pro[i].score[j]);
s+=pro[i].score[j];
}
pro[i].sum=s;
falg=0;
}
void showlist() //全體打印表函數(shù)
{ if(N==0){printf("記錄為空!\n");return;};
printf("\n┏┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┓\n");
printf("┃學(xué)號(hào) 姓名 總成績(jī) 語(yǔ)文 數(shù)學(xué) 英語(yǔ) ┃ \n");
for(int i=1;i<=N;i++)
{
printf("┃%-11s %-10s %-9.1f ",pro[i].num,pro[i].name,pro[i].sum);
for(int j=0;j<3;j++)
printf(j==2?"%-5.1f":"%-8.1f",pro[i].score[j]);
printf("┃\n");
if(i==N)
printf("\n┗┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┛\n");
}
}
void showtable(int n) //個(gè)體打印列表函數(shù)
{
printf("\n┏┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┓\n");
printf("┃學(xué)號(hào):%-11s姓名:%-10s總成績(jī):%-6.1f",pro[n].num,pro[n].name,pro[n].sum);
for(int j=0;j<3;j++)
printf("%s:%-4.1f",classname[j],pro[n].score[j]);
printf(" ┃ \n");
printf("┗┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┛\n");
}
int lookout( ) //查找函數(shù)
{ int tar;
char num[10],name[10];
if(N==0)
{
printf("記錄表為空!\n");
return 0;
}
printf("1.按學(xué)號(hào) 2.按姓名\n請(qǐng)選擇相應(yīng)數(shù)字:");
scanf("%d",&tar);
getchar();
if(tar!=1&&tar!=2)
{printf("選擇無(wú)效!\n");return 0;}
if(tar==2)
{
printf("請(qǐng)輸入查找人的姓名:");
scanf("%s",&name);
for(int i=1;i<=N;i++)
if(strcmp(name,pro[i].name)==0)
{
showtable(i);
return i;
}
}
else
{
printf("請(qǐng)輸入查找人的學(xué)號(hào):");
gets(num);
for(int i=1;i<=N;i++)
if(strcmp(num,pro[i].num)==0)
{
showtable(i);
return i;
}
}
printf("無(wú)該記錄\n");
return 0;
}
void copyrecored(STU *p,STU *q) //復(fù)制函數(shù).
{
strcpy(q->num,p->num);
strcpy(q->name,p->name);
for(int j=0;j<3;j++)
q->score[j]=p->score[j];
q->sum=p->sum;
}
void remove() //刪除個(gè)人信息函數(shù)
{ int b;
char tag[10];
if(N==0){
printf("記錄表為空!\n");
return;
}
b=lookout();
if(b)
{
printf("是否要?jiǎng)h除(y/n):");
gets(tag);
if(tag[0]=='y'||tag[0]=='Y')
{
N--;
for(int j=b;j<=N;j++)
copyrecored(&pro[j+1],&pro[j]);
printf("刪除成功!\n");
falg=0;
}
else printf("刪除失敗!\n");
}
}
void change() //修改個(gè)人信息函數(shù)
{ int m,k,f;
if(N==0)
{printf("記錄表為空!\n");return;}
k=lookout();
if(k)
{
printf("1.學(xué)號(hào) 2.姓名 3科目成績(jī) 4.全部修改 0.退出\n請(qǐng)輸入要修改的信息:");
scanf("%d",&f);
switch(f)
{
case 1:printf("請(qǐng)重新輸入學(xué)號(hào):");
scanf("%s",&pro[k].num );falg=0;break;
case 2:getchar();
printf("請(qǐng)重新輸入姓名:");
scanf("%s",&pro[k].name);falg=0;break;
case 3:printf("0.語(yǔ)文 1.數(shù)學(xué) 2.英語(yǔ)\n請(qǐng)選擇科目:");
scanf("%d",&m);
if(m==0||m==1||m==2)
{
printf("請(qǐng)輸入%s成績(jī):",classname[m]);
scanf("%f",&pro[k].score[m]);
falg=0;
}
else printf("輸入無(wú)效!\n");
pro[k].sum=pro[k].score[0]+pro[k].score[1]+pro[k].score[2];
break;
case 4:newsect(k);break;
default:printf("修改失敗!"); break;
}
}
}
void save() //文件保存函數(shù)
{
FILE *fp;
char fname[30];
if(N==0)
{
printf("沒(méi)有記錄可存!\n");return;
}
loop:printf("請(qǐng)輸入要存入的文件(直接回車保存在默認(rèn)文件中):");
gets(fname);
if(strlen(fname)==0)
strcpy(fname,"stu_info");
if((fp=fopen(fname,"wb"))==NULL){
printf("不能存入文件!\n");goto loop;
}
printf(" 文件保存中....\n");
for(int i=1;i<=N;i++)
if((fwrite(&pro[i],sizeof(STU),1,fp))==0)
{printf("保存失敗!\n");break;}
fclose(fp);
printf("文件已保存!\n");
falg=1;
}
void loadrecords() //讀取文件函數(shù)
{
FILE *fp;
void abc(int s);
char fname[10];
int c;
struct stu records[100];
printf("請(qǐng)輸入要打開(kāi)的文件名(直接回車打開(kāi)默認(rèn)文件):");
gets(fname);
if(strlen(fname)==0)
strcpy(fname,"stu_info");
if((fp=fopen(fname,"rb"))==NULL)
{
printf("文件打不開(kāi)!\n");return;
}
printf("1.覆蓋新建的信息 2.添加到新的信息中 3.查看保存的信息\n請(qǐng)選擇:");
scanf("%d",&c);
if(c==3){
printf("\n┏┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┓\n");
printf("┃學(xué)號(hào) 姓名 總成績(jī) 語(yǔ)文 數(shù)學(xué) 英語(yǔ) ┃ \n");
for(int i=0;fread(&records[i],sizeof(STU),1,fp)!=0;i++)
{
printf("┃%-12s% -11s% -9.1f ",records[i].num ,records[i].name,records[i].sum );
for(int j=0;j<3;j++)
printf(j==2?"%-5.1f":"%-8.1f",records[i].score [j]);
printf(" ┃\n");
}
printf("\n┗┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┛\n");
}
if(c==1){
abc(0);
for( N=1;fread(&pro[N],sizeof(STU),1,fp)!=0;N++);
N--; //跳出循環(huán),N實(shí)際比得到人數(shù)要大一,故要減一。
falg=0;
fclose(fp);
showlist();
}
if(c==2){falg=0;
for(++N;fread(&pro[N],sizeof(STU),1,fp)!=0;N++)
if(N>arrysize){
pro=(STU*)realloc(pro,sizeof(STU)*(arrysize+size)); //超出內(nèi)存,就分配新的內(nèi)存。
}
arrysize+=size;
N--; //跳出循環(huán),N實(shí)際比得到人數(shù)要大一,故要減一。
fclose(fp);
showlist();
}
}
void abc(int s) //信息保存判斷函數(shù) s代表要進(jìn)行的相應(yīng)操作。
{ char v[10];
if(N!=0&&falg!=1)
{
printf("新建信息尚未保存!,繼續(xù)將會(huì)使新建的信息消失,");
printf("是否先保存(y/n):");
while(1){
gets(v);
if(v[0]=='y'||v[0]=='Y') {save();break;}
if(v[0]=='n'||v[0]=='N') break;
else printf("輸入有誤!請(qǐng)重新輸入:");
}
}
if(s==1){
printf("請(qǐng)輸入統(tǒng)計(jì)人的個(gè)數(shù):");
scanf("%d",&N);
gets(v); //消除違規(guī)數(shù)據(jù)。
for(int i=1;i<=N;i++)
newsect(i);
}
else return;
}
void main() //主函數(shù)
{ char v[10];
int choice,c;
pro=(STU*)malloc(size*sizeof(STU));
if(pro==NULL)
{
printf("內(nèi)存分配出錯(cuò)!\n");
return;
}
printf("\t\t\t\t學(xué)生成績(jī)管理系統(tǒng)\n\n");
do
{ choice=-1;
printf("\n0.新建\t\t1.添加\t\t\t2.查找\t3.刪除\n4.列表輸出\t5.排序\t\t\t6修改\n7.文件保存\t8.讀取保存的記錄文件\t9退出\n請(qǐng)選擇相應(yīng)的操作:");
scanf("%d",&choice);
gets(v); //消除違規(guī)數(shù)據(jù),防止變成死循環(huán)
switch(choice)
{case 0:abc(1);break;
case 1:++N;newsect(N);break;
case 2:lookout();break;
case 3:remove();break;
case 6:change();het(1,N,1);break;
case 5:if(N==0){printf("記錄為空!\n");break;}
else {printf("1.按成績(jī)降序 2.按成績(jī)升序 3.按學(xué)號(hào)升序 4.按學(xué)號(hào)降序\n請(qǐng)選擇相應(yīng)功能:");
scanf("%d",&c);het(1,N,c);}
case 4:showlist();break;
case 7:save();break;
case 8:loadrecords();break;
case 9:abc(0);printf("謝謝使用!\n");break;
default:printf("選擇無(wú)效!\n");break;
}
}
while(choice!=9);
}
更多學(xué)習(xí)資料請(qǐng)關(guān)注專題《管理系統(tǒng)開(kāi)發(fā)》。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- C語(yǔ)言編寫(xiě)學(xué)生成績(jī)管理系統(tǒng)
- 學(xué)生成績(jī)管理系統(tǒng)C語(yǔ)言代碼實(shí)現(xiàn)
- C語(yǔ)言利用結(jié)構(gòu)體數(shù)組實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)
- C語(yǔ)言學(xué)生成績(jī)管理系統(tǒng)源代碼
- C語(yǔ)言實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)實(shí)戰(zhàn)教學(xué)
- C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單學(xué)生成績(jī)管理系統(tǒng)
- C語(yǔ)言結(jié)構(gòu)體版學(xué)生成績(jī)管理系統(tǒng)
- 使用C語(yǔ)言實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)
- C語(yǔ)言實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)
- 基于C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單學(xué)生成績(jī)管理系統(tǒng)
相關(guān)文章
C++實(shí)現(xiàn)從數(shù)組中同時(shí)取出最大最小元素算法示例
這篇文章主要介紹了C++實(shí)現(xiàn)從數(shù)組中同時(shí)取出最大最小元素算法,結(jié)合具體實(shí)例形式分析了C++通過(guò)數(shù)組的遍歷、排序獲取最大與最小元素的相關(guān)操作技巧,需要的朋友可以參考下2017-09-09
VC創(chuàng)建進(jìn)程CreateProcess的方法
這篇文章主要介紹了VC創(chuàng)建進(jìn)程CreateProcess的方法,涉及VC操作進(jìn)程的基本技巧,需要的朋友可以參考下2015-05-05
C語(yǔ)言實(shí)現(xiàn)逆波蘭式實(shí)例
這篇文章介紹了C語(yǔ)言實(shí)現(xiàn)逆波蘭式實(shí)例,有需要的朋友可以參考一下2013-09-09
Matlab實(shí)現(xiàn)帶豎線散點(diǎn)的核密度圖的繪制
核密度估計(jì)是用于估計(jì)隨機(jī)變量概率密度函數(shù)的一種非參數(shù)方法。核密度圖不失為一種用來(lái)觀察連續(xù)型變量分布的有效方法。本文將用Matlab實(shí)現(xiàn)帶豎線散點(diǎn)的核密度圖的繪制,感興趣的可以了解一下2022-08-08
dev-c++創(chuàng)建lib(靜態(tài)鏈接庫(kù))文件的實(shí)現(xiàn)步驟
本文主要介紹了dev-c++創(chuàng)建lib(靜態(tài)鏈接庫(kù))文件的實(shí)現(xiàn)步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06
OpenCV實(shí)現(xiàn)Sobel邊緣檢測(cè)的示例
本文主要介紹了OpenCV實(shí)現(xiàn)Sobel邊緣檢測(cè)的示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08
C語(yǔ)言詳解數(shù)據(jù)結(jié)構(gòu)與算法中枚舉和模擬及排序
枚舉和模擬其實(shí)是沒(méi)什么算法可言的,大多數(shù)都是按照題目意思去寫(xiě),這里提供快排和歸并的兩個(gè)模板,感興趣的朋友來(lái)看看吧2022-04-04

