C語言模擬實(shí)現(xiàn)學(xué)生學(xué)籍管理系統(tǒng)
學(xué)生學(xué)籍管理系統(tǒng)的C語言模擬實(shí)現(xiàn)是對鏈表、指針、結(jié)構(gòu)體、文件操作等知識(shí)點(diǎn)的綜合運(yùn)用,需要實(shí)現(xiàn)的功能主要包含:輸入學(xué)生信息、顯示學(xué)生信息、查詢學(xué)生信息、新增學(xué)生信息、刪除學(xué)生信息、修改學(xué)生信息、對學(xué)生信息排序、保存當(dāng)前信息到文件、文件備份、文件加載等。
代碼實(shí)現(xiàn)如下
#include <stdio.h> #include <malloc.h> #include <string.h> #include <stdlib.h> #include<conio.h> #include <MEMORY.H> typedef struct node { ? ? ? ? ? ? ? ? ?? ? ? ?int ? ?num; ? ? ?char ? name[20]; ? ? ?float ?score[3]; ? ? ?float ?ave; ? ? struct ?node *next; }STU; STU *Create(); void output(STU *head); void find(STU *head); STU *findByNum(STU *head,int num); STU *findByName(STU *head,char name); STU *findByNumEx(STU *head,int num,STU **ppbefore); STU *del(STU* head); STU *insert(STU *head); void update(STU *head); void sort(STU *head); void save_info(STU *head); STU *load_info(); void copy(); void main() { ?? ? ? STU *head; ? ? int choice; ? ? head=NULL; ? ? for(;;) ? ? { ? ? ? ? system("cls"); ? ? ? ? printf(" ? ? ? ? ? \t\t******學(xué)生成績管理系統(tǒng)*********\n"); ? ? ? ? printf(" ? ? ? ? ? \t\t* 1.輸入學(xué)生信息 ? ? ? ? ? ? ?*\n"); ? ? ? ? printf(" ? ? ? ? ? \t\t* 2.顯示全部學(xué)生信息 ? ? ? ? ?*\n"); ? ? ? ? printf(" ? ? ? ? ? \t\t* 3.查詢學(xué)生信息 ? ? ? ? ? ? ?*\n"); ? ? ? ? printf(" ? ? ? ? ? \t\t* 4.新增學(xué)生信息 ? ? ? ? ? ? ?*\n"); ? ? ? ? printf(" ? ? ? ? ? \t\t* 5.刪除學(xué)生信息 ? ? ? ? ? ? ?*\n"); ? ? ? ? printf(" ? ? ? ? ? \t\t* 6.修改學(xué)生信息 ? ? ? ? ? ? ?*\n"); ? ? ? ? printf(" ? ? ? ? ? \t\t* 7.對學(xué)生信息排序 ? ? ? ? ? ?*\n"); ? ? ? ? printf(" ? ? ? ? ? \t\t* 8.保存當(dāng)前信息到文件 ? ? ? ?*\n"); ? ? ? ? printf(" ? ? ? ? ? \t\t* 9.備份 ? ? ? ? ? ? ? ? ? ? ?*\n"); ? ? ? ? printf(" ? ? ? ? ? \t\t* 10.從文件加載學(xué)生信息 ? ? ? *\n"); ? ? ? ? printf(" ? ? ? ? ? \t\t* 0.退出系統(tǒng) ? ? ? ? ? ? ? ? ?*\n"); ? ? ? ? printf(" ? ? ? ? ? \t\t*******************************\n"); ? ? ? ? printf("請選擇(0-9) :"); ? ? ? ? scanf("%d",&choice); ? ? ? ? if(choice==0) break; ? ? ? ? switch(choice) ? ? ? ? { ?? ? ? ? ? ? ? case 1: head=Create();break; ? ? ? ? ? ? case 2: output(head);break; ? ? ? ? ? ? case 3: find(head);break; ? ? ? ? ? ? case 4: head=insert(head); break; ? ? ? ? ? ? case 5: head=del(head); break; ? ? ? ? ? ? case 6: update(head);break; ? ? ? ? ? ? case 7: sort(head);break; ? ? ? ? ? ? case 8: save_info(head);break; ? ? ? ? ? ? case 9: copy();break; ? ? ? ? ? ? case 10:head=load_info();break; ? ? ? ?} ? ? printf("按任意鍵繼續(xù)...."); ? ? getch(); ? ? } ? ? printf("感謝您的使用,再見!\n"); } STU *Create() { ? ? STU *head,*pnew,*pend; ? ? head=NULL; ? ? printf("輸入學(xué)生信息(按0結(jié)束輸入):\n學(xué)號(hào)\t姓名\t數(shù)學(xué)\t英語\t語文\n"); ? ? for(;;) ? ? { ? ? ? ? pnew=(STU *)malloc(sizeof(STU)); ? ? ? ? scanf("%d",&pnew->num); ? ? ? ? if(pnew->num==0) ? ? ? ? { ?? ? ? ? ? ? ? printf("輸入完成!---> "); ? ? ? ? ? ? break; ? ? ? ? } ? ? ? ? scanf("%s%f%f%f",pnew->name,&pnew->score[0],&pnew->score[1],&pnew->score[2]); ? ? ? ? pnew->ave=(pnew->score[0]+pnew->score[1]+pnew->score[2])/3; ? ? ? ? pnew->next=NULL; ? ? ? ? if(head==NULL) ? ? ? ? { ? ? ? ? ? ? head=pnew; ? ? ? ? ? ? pend=pnew; ? ? ? ? } ? ? ? ? else ? ? ? ? { ? ? ? ? ? ? pend->next=pnew; ? ? ? ? ? ? pend=pend->next; ? ? ? ? } ? ? } ? ? return head; } void output(STU *head) { ? ? STU *p; ? ? printf("全部學(xué)生信息如下:\n學(xué)號(hào)\t姓名\t數(shù)學(xué)\t英語\t語文\t平均分\n"); ? ? for(p=head;p!=NULL;p=p->next) ? ? ? ? printf("%d\t%s\t%.2f\t%.2f\t%.2f\t%.2f\n",p->num,p->name,p->score[0],p->score[1],p->score[2],p->ave); } void find(STU *head) { ? ? STU *presult; ? ? int num; ? ? char name[20]; ? ? int choice; ? ? printf("查找學(xué)生信息\n"); ? ? printf("請選擇查找方式:1,按學(xué)號(hào);2,按姓名\n"); ? ? printf("choice="); ? ? scanf("%d",&choice); ? ? if(choice==1) ? ? { ? ? printf("請輸入學(xué)號(hào):"); ? ? scanf("%d",&num); ? ? presult=findByNum(head,num); ? ? } ? ? else ? ? { ? ? ? ? printf("請輸入姓名\n"); ? ? ? ? scanf("%s",name); ? ? ? ? presult=findByName(head,name); ? ? } ? ? if(presult!=NULL) ? ? { ? ? ? ? printf("找到了,該生信息如下:\n學(xué)號(hào)\t姓名\t數(shù)學(xué)\t英語\t語文\t平均分\n"); ?? ? ? ? ? printf("%d\t%s\t%.2f\t%.2f\t%.2f\t%.2f\n",presult->num,presult->name,presult->score[0],presult->score[1],presult->score[2],presult->ave); ? ? } ? ? else ? ? ? ? printf("查無此人!\a\n"); } STU *findByNum(STU *head,int num) { ? ? STU *p,*presult=NULL; ? ? for(p=head;p!=NULL;p=p->next) ? ? ? ? if(p->num==num) ? ? ? ? { ? ? ? ? ? ? presult=p; ? ? ? ? ? ? break; ? ? ? ? } return presult; } STU *findByName(STU *head,char *name) { ? ? STU *p,*presult=NULL; ? ? for(p=head;p!=NULL;p=p->next) ? ? ? ? if(strcmp(p->name,name)==0) ? ? ? ? { ? ? ? ? ? ? presult=p; ? ? ? ? ? ? break; ? ? ? ? } return presult; } //函數(shù)說明: // ?在head所指向鏈表中,查找學(xué)號(hào)為num的節(jié)點(diǎn) // ?找到后,返回兩個(gè)值:指向當(dāng)前節(jié)點(diǎn)的指針presult,指向當(dāng)前節(jié)點(diǎn)的前一節(jié)點(diǎn)的指針pbefore, // ?presult通過函數(shù)返回值返回(即return),pbefore通過輸出型參數(shù)ppBefore返回 STU *findByNumEx(STU *head,int num,STU **ppbefore) { ? ? STU *p,*presult=NULL,*pbefore=NULL; ? ? for(p=head;p!=NULL;pbefore=p,p=p->next) ? ? ? ? if(p->num==num) ? ? ? ? { ? ? ? ? ? ? presult=p; ? ? ? ? ? ? break; ? ? ? ? } ? ? if(p==NULL) ? ? pbefore=NULL; ? ? *ppbefore=pbefore; ? ? return presult; } STU *del(STU *head) { ? ? STU *presult,*pbefore; ? ? int num; ? ? printf("要?jiǎng)h除的學(xué)號(hào):"); ? ? scanf("%d",&num); ? ? presult=findByNumEx(head,num,&pbefore); ? ? if(presult!=NULL) ? ? { ? ? ? ? printf("找到了,該生信息如下:\n學(xué)號(hào)\t姓名\t數(shù)學(xué)\t英語\t語文\t平均分\n"); ?? ? ? ? ? printf("%d\t%s\t%.2f\t%.2f\t%.2f\t%.2f\n",presult->num,presult->name,presult->score[0],presult->score[1],presult->score[2],presult->ave); ? ? ? ? if(presult==head) ? ? ? ? { ? ? ? ? ? ? head=presult->next; ? ? ? ? } ? ? ? ? else ? ? ? ? { ? ? ? ? ? ? pbefore->next=presult->next; ? ? ? ? } ? ? ? ? printf("刪除成功---> "); ? ? } ? ? else ? ? ? ? printf("無與此學(xué)生相關(guān)的信息\a\a\n"); ? ? return head; } STU *insert(STU *head) { ? ? STU *pnew,*pcur,*pbefore,*p; ? ? int choice; ? ? printf("輸入新生信息:\n"); ? ? for(;;) ? ? { ? ? ? ? pnew=(STU *)malloc(sizeof(STU)); ? ? ? ? printf("學(xué)號(hào)\t姓名\t數(shù)學(xué)\t英語\t語文\n"); ? ? ? ? scanf("%d%s%f%f%f",&pnew->num,pnew->name,&pnew->score[0],&pnew->score[1],&pnew->score[2]); ? ? ? ? pnew->ave=(pnew->score[0]+pnew->score[1]+pnew->score[2])/3; ? ? ? ? pnew->next=NULL; ? ? if(head==NULL) ? ? { ? ? ? ? head=pnew; ? ? ? } ? ? else ? ? { ? ? ? ? pcur=NULL; ? ? ? ? for(p=head;p!=NULL;pbefore=p,p=p->next) ? ? ? ? ? ? if(p->num > pnew->num) ? ? ? ? ? ? { ? ? ? ? ? ? ? ? pcur=p; ? ? ? ? ? ? ? ? break; ? ? ? ? ? ? } ? ? ?? ? ? ? ? if(pcur==NULL) ? ? ? ? { ? ? ? ? ? ? pbefore->next=pnew;? ? ? ? ? } ? ? ? ? else ? ? ? ? { ? ? ? ? ? ? if(pcur==head) ? ? ? ? ? ? { ? ? ? ? ? ? ? ? pnew->next=pcur; ? ? ? ? ? ? ? ? head=pnew; ? ? ? ? ? ? } ? ? ? ? ? ? else ? ? ? ? ? ? { ? ? ? ? ? ? ? ? pnew->next=pcur; ? ? ? ? ? ? ? ? pbefore->next=pnew; ? ? ? ? ? ? } ? ? ? ? } ? ? } ? ? printf("請選擇:按1繼續(xù)添加->按0結(jié)束添加\n"); ? ? printf("choice="); ? ? scanf("%d",&choice); ? ? if(choice==0) ? ? ? ? { ?? ? ? ? ? ? ? printf("信息添加完畢!\n"); ? ? ? ? ? ? break; ? ? ? ? } ? ? } ? ? return head; } void update(STU *head) { ? ? STU *presult; ? ? int num; ? ? printf("輸入要修改學(xué)生的學(xué)號(hào)\n"); ? ? scanf("%d",&num); ? ? presult=findByNum(head,num); ? ? if(presult==NULL) ? ? ? ? printf("查無此人!無法修改!\a\n"); ? ? else ? ? { ? ? ? ? printf("找到了,該生信息如下:\n學(xué)號(hào)\t姓名\t數(shù)學(xué)\t英語\t語文\t平均分\n"); ?? ? ? ? ? printf("%d\t%s\t%.2f\t%.2f\t%.2f\t%.2f\n",presult->num,presult->name,presult->score[0],presult->score[1],presult->score[2],presult->ave); ? ? ? ? printf("輸入修改信息\n"); ? ? ? ? printf("學(xué)號(hào)\t姓名\t數(shù)學(xué)\t英語\t語文\n");? ? ? ? ? scanf("%d%s%f%f%f",&presult->num,&presult->name,&presult->score[0],&presult->score[1],&presult->score[2]); ? ? ? ? presult->ave=(presult->score[0]+presult->score[1]+presult->score[2])/3; ? ? ? ? printf("修改完畢---> "); ? ? } } void sort(STU *head) { ? ? STU *pi,*pj,*pindex,*p; ? ? STU temp; ? ? int len=sizeof(STU)-sizeof(STU *); ? ? int i,j,n=0; ? ? for(p=head;p!=NULL;p=p->next) ? ? ? ? n++; ? ? for(pi=head,i=0;i<n-1;i++,pi=pi->next){ ? ? ? ? pindex=pi; ? ? ? ? for(pj=pi->next,j=i+1;j<n;j++,pj=pj->next) ? ? ? ? ? ? if(pindex->num> pj->num) ? ? ? ? ? ? ? ? pindex=pj; ? ? ? ? ? ? memcpy(&temp,pi,len);? ? ? ? ? memcpy(pi,pindex,len);? ? ? ? ? memcpy(pindex,&temp,len);? ? ? } ? ? printf("排序完畢---> "); } void save_info(STU *head) { ? ? char filename[40]; ? ? FILE *fp; ? ? STU *p; ? ? printf("現(xiàn)在進(jìn)入保存當(dāng)前信息到文件的處理\n"); ? ? printf("請輸入文件名:"); ? ? scanf("%s",filename); ? ? if((fp=fopen(filename,"w"))==NULL) ? ? { ? ? ? ? printf("無法打開文件\n"); ? ? ? ? return; ? ? } ? ? fprintf(fp,"全部學(xué)生信息如下:\n學(xué)號(hào)\t姓名\t數(shù)學(xué)\t英語\t語文\t平均分\n"); ? ? for(p=head;p!=NULL;p=p->next) ? ? fprintf(fp,"%d\t%s\t%.2f\t%.2f\t%.2f\t%.2f\n",p->num,p->name,p->score[0],p->score[1],p->score[2],p->ave); ? ? fprintf(fp,"%d",0); ? ? fclose(fp); ? ? printf("保存完成!--->"); } STU *load_info() { ? ? STU *head=NULL,*pnew,*pend; ? ? char filename[40]; ? ? FILE *fp; ? ? int i; ? ? printf("現(xiàn)在進(jìn)行從文件加載的處理,輸入文件名:"); ? ? scanf("%s",filename); ? ? if((fp=fopen(filename,"r"))==NULL){ ? ? ? ? printf("加載失敗!"); ? ? ? ? exit(0); ? ? } ? ? for(i=0;i<7;i++) ? ? ? ? fscanf(fp,"%s",filename); ? ? for(;;) ? ? { ? ? ? ? pnew=(STU *)malloc(sizeof(STU)); ? ? ? ? fscanf(fp,"%d",&pnew->num); ? ? ? ? ? ? if(pnew->num==0) ? ? ? ? ? ? ? ? break; ? ? ? ? fscanf(fp,"%s%f%f%f%f",&pnew->name,&pnew->score[0],&pnew->score[1],&pnew->score[2],&pnew->ave); ? ? ? ? pnew->next=NULL; ? ? ? ? if(head==NULL) ? ? ? ? { ? ? ? ? ? ? head=pnew; ? ? ? ? ? ? pend=pnew; ? ? ? ? } ? ? ? ? else ? ? ? ? { ? ? ? ? ? ? pend->next=pnew; ? ? ? ? ? ? pend=pnew; ? ? ? ? } ? ? } ? ? fclose(fp); ? ? printf("加載成功!\n"); ? ? return head; } void copy() { ? ? FILE *in,*out; ? ? char infile[40]; ? ? char outfile[40]; ? ? printf("現(xiàn)在進(jìn)入學(xué)生信息文件的備份\n"); ? ? printf("源文件名:"); ? ? scanf("%s",infile); ? ? printf("備份文件名:"); ? ? scanf("%s",outfile); ? ? if((in=fopen(infile,"r"))==NULL) ? ? { ? ? ? ? printf("文件無法打開\n"); ? ? ? ? exit(0); ? ? } ? ? if((out=fopen(outfile,"w"))==NULL){ ? ? ? ? printf("文件無法打開\n"); ? ? ? ? exit(0); ? ? } ? ? while(!feof(in)) ? ? ? ? fputc(fgetc(in),out); ? ? ? ? fclose(in); ? ? ? ? fclose(out); }
程序運(yùn)行效果圖:
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- C語言實(shí)現(xiàn)學(xué)籍信息管理系統(tǒng)
- C語言實(shí)現(xiàn)學(xué)生學(xué)籍管理系統(tǒng)課程設(shè)計(jì)
- C語言實(shí)現(xiàn)學(xué)籍管理系統(tǒng)課程設(shè)計(jì)
- C語言實(shí)現(xiàn)學(xué)生學(xué)籍管理系統(tǒng)程序設(shè)計(jì)
- C語言實(shí)現(xiàn)學(xué)籍管理系統(tǒng)
- C語言學(xué)籍管理系統(tǒng)源代碼
- C語言實(shí)現(xiàn)學(xué)生學(xué)籍管理系統(tǒng)
- C語言學(xué)生學(xué)籍管理系統(tǒng)課程設(shè)計(jì)
- C語言實(shí)現(xiàn)簡單學(xué)生學(xué)籍管理系統(tǒng)
- C語言動(dòng)態(tài)鏈表實(shí)現(xiàn)學(xué)生學(xué)籍管理系統(tǒng)
相關(guān)文章
Ubuntu18.04上安裝Qt5.10的步驟實(shí)踐
Qt是一個(gè)跨平臺(tái)的C++圖形用戶界面庫,本文就介紹了Ubuntu18.04上安裝Qt5.10的步驟實(shí)踐,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11用VC++6.0實(shí)現(xiàn)石頭剪刀布游戲的程序
最先看到這個(gè)游戲代碼是python版的,后來看到有小伙伴用VC++重寫了一遍,運(yùn)行之后發(fā)現(xiàn)有些小bug,便嘗試這修復(fù)了一下,并增加了些小功能,這里分享給大家。2015-03-03opengl實(shí)現(xiàn)任意兩點(diǎn)間畫圓柱體
這篇文章主要為大家詳細(xì)介紹了opengl實(shí)現(xiàn)任意兩點(diǎn)間畫圓柱體,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-06-06C++類中的常數(shù)據(jù)成員與靜態(tài)數(shù)據(jù)成員之間的區(qū)別
常數(shù)據(jù)成員是指在類中定義的不能修改其值的一些數(shù)據(jù)成員,類似于我們以前學(xué)過的常變量,雖然是變量,也有自己的地址,但是一經(jīng)賦初值,便不能再被修改2013-10-10C++基于socket多線程實(shí)現(xiàn)網(wǎng)絡(luò)聊天室
這篇文章主要為大家詳細(xì)介紹了C++基于socket多線程實(shí)現(xiàn)網(wǎng)絡(luò)聊天室,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07基于Matlab實(shí)現(xiàn)有雪花飄落的圣誕樹的繪制
圣誕節(jié)快到了(雖然還有十天),一起來用MATLAB畫個(gè)簡單圣誕樹叭~代碼幾乎取消了全部的循環(huán),因此至少需要17b之后的版本,僅存的循環(huán)用來讓樹旋轉(zhuǎn)起來,讓雪花飄落起來,讓樹頂上的星光搖曳起來~感興趣的可以試一試2022-12-12