C語(yǔ)言學(xué)生信息管理系統(tǒng)
本文實(shí)例為大家分享了C語(yǔ)言學(xué)生信息管理系統(tǒng)的具體代碼,供大家參考,具體內(nèi)容如下
列表內(nèi)容
系統(tǒng)以菜單方式工作
學(xué)生信息錄入功能(學(xué)生信息用文件保存)—輸入
學(xué)生信息瀏覽功能——輸出
查詢(xún)、排序功能——算法
1、按學(xué)號(hào)查詢(xún)
2、按姓名查詢(xún)
學(xué)生信息的刪除與修改
界面簡(jiǎn)單明了;
有一定的容錯(cuò)能力,比如輸入的成績(jī)不在0~100之間,就提示不合法,要求重新
輸入;
用鏈表的方式實(shí)現(xiàn)。
#include <stdio.h> #include <string.h> #include <stdlib.h> #include <windows.h> #include <string.h> typedef struct Student { char name[100]; //姓名 char num[100]; //學(xué)號(hào) char sex;//性別 (w代表女生m代表男生) int age;//年齡 int score;//成績(jī) }stu; typedef struct LNode { stu data; struct LNode *next; }LinkList; char nam[100];//名字 char nu[100];//學(xué)號(hào) char s;//性別 int ag;//年齡 int sc;//成績(jī) void welocome()//登陸界面 { system("color b1"); printf("````````````````````````````````````````````````````````````````````````````````"); printf("\n"); printf("\n"); printf("\n"); printf(" *********************** 歡迎登錄學(xué)生信息管理平臺(tái) ************************* \n"); printf("\n"); printf("\n"); printf("\n"); printf("````````````````````````````````````````````````````````````````````````````````"); } void menu()//功能菜單 { system("color e3"); printf(" |________________________________________________|\n"); printf(" | |\n"); printf(" | 學(xué)生信息管理系統(tǒng) |\n"); printf(" | |\n"); printf(" | 0、退出系統(tǒng) |\n"); printf(" | 1、增加學(xué)生信息 |\n"); printf(" | 2、刪除學(xué)生信息 |\n"); printf(" | 3、修改學(xué)生信息 |\n"); printf(" | 4、查找學(xué)生的信息 |\n"); printf(" | 5、按照學(xué)生成績(jī)排序 |\n"); printf(" | 6、瀏覽全部學(xué)生信息 |\n"); printf(" | 7、保存學(xué)生信息到文件 |\n"); printf(" | |\n"); printf(" |________________________________________________|\n"); return ; } void InitList( LinkList *&L)//初始化鏈表 { L=(LinkList *)malloc(sizeof(LinkList)); L->next=NULL; } void ListInsert(LinkList *&L,LinkList *p)//插入新的節(jié)點(diǎn) { LinkList *q=NULL; q=L; p->next=q->next; q->next=p; } void addstu(LinkList *&L)//增加新的學(xué)生 { system("color f2"); printf("請(qǐng)輸入學(xué)生的信息:\n"); printf("學(xué)號(hào):"); scanf("%s",nu); LinkList *q=L->next; while(q!=NULL ) { if(strcmp(q->data.num,nu)==0)//判斷是否存在 { printf("該生已存在\n"); break; } q=q->next; } if(q==NULL) { LinkList *p; InitList(p); strcpy(p->data.num,nu); printf("姓名:") ; scanf("%s",nam) ; strcpy(p->data.name,nam); printf("性別:(w為男 m為女)"); scanf(" %c",&s); p->data.sex=s; printf("年齡:"); scanf("%d",&ag); p->data.age=ag; printf("總成績(jī):"); scanf("%d",&sc); while(sc>100||sc<0){ printf("輸入有誤,請(qǐng)重新輸入\n"); scanf("%d",&sc); } p->data.score=sc; ListInsert(L,p); } } void deletestu(LinkList *L)//刪除學(xué)生 { system("color f4"); printf("請(qǐng)輸入您要?jiǎng)h除的學(xué)生的學(xué)號(hào):"); scanf("%s",nu); //判斷 LinkList *p,*pre; if(L->next==NULL) { printf("還沒(méi)有學(xué)生信息,請(qǐng)?jiān)黾訉W(xué)生信息\n"); return; } pre=L; p=pre->next; int judge=0; while(p) { if(strcmp(p->data.num,nu)==0) { judge=1; pre->next =p->next; free(p); printf("刪除學(xué)生成功\n"); break; } pre=p; p=p->next; } if(judge==0) printf("該生不存在\n"); } void changestu(LinkList *L)//改變學(xué)生信息 { int judge=1; system("color e4"); printf("請(qǐng)輸入您要修改學(xué)生的學(xué)號(hào):\n"); scanf("%s",nu); LinkList *q=L->next; while(q!=NULL ) { if(strcmp(q->data.num,nu)==0) { judge=1; printf("請(qǐng)輸入您要修改的信息選項(xiàng):1.姓名 2. 總成績(jī) 3.年齡 \n"); int n; scanf("%d",&n); switch(n) { case 1: printf("請(qǐng)輸入您要修改的名字:"); scanf("%s",nam); printf("修改的名字為:%s\n",nam); strcpy(q->data.name,nam); printf("修改名字成功!\n"); break; case 2: printf("請(qǐng)輸入您要修改的總成績(jī)"); scanf("%d",&sc); printf("修改的總成績(jī)?yōu)椋?d\n",sc); q->data.score=sc; printf("修改總成績(jī)成功!\n"); break; case 3: printf("請(qǐng)輸入您要修改的年齡:"); scanf("%d",&ag); printf("修改的年齡為:%d\n",ag); q->data.age=ag; printf("修改年齡成功!\n"); break; default : printf("請(qǐng)輸入正確的選項(xiàng)\n"); break; } } q=q->next; } if(judge==0) { printf("該生不存在\n"); } } void findstu(LinkList *L)//按學(xué)號(hào)或者姓名查找學(xué)生并輸出該生信息 { int flag; system("color b1"); printf("1.按學(xué)號(hào)查詢(xún):\n"); printf("2.按姓名查詢(xún):\n"); printf("請(qǐng)輸入查詢(xún)方式:"); scanf("%d",&flag); if(flag==1){ printf("請(qǐng)輸入該生學(xué)號(hào):"); scanf("%s",nu); //判斷 LinkList *q=L->next; while(q!=NULL ) { if(strcmp(q->data.num,nu)==0) { printf("姓名:%s\n",q->data.name); printf("學(xué)號(hào):%s\n",q->data.num); printf("性別:%c\n",q->data.sex); printf("年齡:%d\n",q->data.age); printf("總成績(jī):%d\n",q->data.score); break; } q=q->next; } if(q==NULL) printf("該生不存在\n"); }else{ printf("請(qǐng)輸入該生姓名:"); scanf("%s",nam); LinkList *q=L->next; while(q!=NULL ) { if(strcmp(q->data.name,nam)==0) { printf("姓名:%s\n",q->data.name); printf("學(xué)號(hào):%s\n",q->data.num); printf("性別:%c\n",q->data.sex); printf("年齡:%d\n",q->data.age); printf("總成績(jī):%d\n",q->data.score); break; } q=q->next; } if(q==NULL) printf("該生不存在\n"); } } void display(LinkList *&L)//瀏覽全部學(xué)生信息 { LinkList *q=L->next; if(q==NULL) { printf("還沒(méi)有學(xué)生信息,請(qǐng)?jiān)黾訉W(xué)生信息\n"); return; } while(q) { system("color c0"); printf(" 學(xué)號(hào):%s 名字:%s 年齡:%d 性別:%c 總成績(jī):%d \n",q->data.num,q->data.name,q->data.age,q->data.sex, q->data.score); q=q->next; } } void paixu(LinkList *L)//按成績(jī)排序排序 并輸出排序后的結(jié)果 { system("color f9"); LinkList *q,*p,*r=L->next; //判斷 if(r==NULL) { printf("還沒(méi)有學(xué)生信息,請(qǐng)?jiān)黾訉W(xué)生信息\n"); return; } while(r) //兩層循環(huán)完成排序 { p=r; q=r->next; LinkList *tmp;//用于排序時(shí)暫存節(jié)點(diǎn) InitList(tmp); while(q) { if(q->data.score > p->data.score) { /*先復(fù)制q結(jié)點(diǎn)信息到tmp*/ strcpy(tmp->data.num,q->data.num); strcpy(tmp->data.name,q->data.name); tmp->data.sex=q->data.sex; tmp->data.age=q->data.age; tmp->data.score=q->data.score; /*再?gòu)?fù)制p結(jié)點(diǎn)信息到q*/ strcpy(q->data.num,p->data.num); strcpy(q->data.name,p->data.name); q->data.sex=p->data.sex; q->data.age=p->data.age; q->data.score=p->data.score; /*最后復(fù)制exchange結(jié)點(diǎn)信息到p*/ strcpy(p->data.num,tmp->data.num); strcpy(p->data.name,tmp->data.name); p->data.sex=tmp->data.sex; p->data.age=tmp->data.age; p->data.score=tmp->data.score; } q=q->next; } r=r->next; } printf("排序后的學(xué)生信息是:\n"); display(L); } void saveStuDentFile(LinkList * &L)//保存學(xué)生信息到文件 { FILE *fp; LinkList *p=L->next; if((fp=fopen("student.txt","w"))==NULL)// 以可寫(xiě)的方式打開(kāi)當(dāng)前目錄下的.txt { printf("不能打開(kāi)此文件,請(qǐng)按任意鍵退出\n"); exit(1); } while(p) { fprintf(fp,"%s %s %c %d %d \n",p->data.num,p->data.name,p->data.sex,p->data.age,p->data.score); p=p->next; printf("保存成功\n"); } fclose(fp); } void readStuDentput (LinkList *&L) //運(yùn)行前把文件內(nèi)容讀取到電腦內(nèi)存 { FILE *fp; fp=fopen("student.txt","rb"); //以只讀方式打開(kāi)當(dāng)前目錄下的.txt if(fp==NULL) { printf("不存在打開(kāi)文件\n"); exit(0); //終止程序 } int i=0; while(!feof(fp)) { char nu[100];//學(xué)號(hào) char nam[100];//名字 char s;//性別 int ag;//年齡 int sc;//成績(jī) fscanf(fp," %s %s %c %d %d",nu,nam,&s,&ag,&sc); i++; } fclose(fp); FILE *FP; FP=fopen("student.txt","rb"); //以只讀方式打開(kāi)當(dāng)前目錄下的.txt if(FP==NULL) { printf("無(wú)法打開(kāi)文件\n"); exit(0); //終止程序 } int b=i-1; int j=1; while(!feof(FP)) { fscanf(FP,"%s %s %c %d %d",nu,nam,&s,&ag,&sc); LinkList *n=(LinkList *)malloc(sizeof(LinkList)); strcpy(n->data.num,nu);//把后者的內(nèi)容拷貝到前者中 strcpy(n->data.name,nam);//把后者的內(nèi)容拷貝到前者中 n->data.sex=s; n->data.age=ag; n->data.score=sc; ListInsert(L,n);//插入新的節(jié)點(diǎn) n=n->next; if(j==b) break; j++; } fclose(FP); //關(guān)閉文件 } int main() { system("cls");//清屏 welocome();//登陸界面 Sleep(3000);//延緩3秒 LinkList *L; InitList(L); readStuDentput (L);//運(yùn)行前把文件內(nèi)容讀取到電腦 int a; int choose; while(1) { printf("請(qǐng)輸入您要選擇的功能鍵:\n"); menu();//功能菜單 scanf("%d",&choose); switch(choose) { case 0://退出 printf("謝謝使用!歡迎下次光臨"); exit(0); case 1://增加學(xué)生信息 addstu(L);//增加新的學(xué)生 break; case 2://刪除所有學(xué)生信息 deletestu(L);//刪除學(xué)生 break; case 3://改變個(gè)學(xué)生的信息 changestu(L);//改變學(xué)生信息 break; case 4://查找某個(gè)學(xué)生的信息 findstu(L);//按學(xué)號(hào)查找學(xué)生并輸出該生信息 break; case 5:// 對(duì)學(xué)生成績(jī)進(jìn)行排序 paixu(L); break; case 6://輸出所有學(xué)生的信息 display(L); break; case 7://保存學(xué)生信息到文件 saveStuDentFile(L); break; default: printf("請(qǐng)輸入正確的選擇\n"); break; } } }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
解析C++中多層派生時(shí)的構(gòu)造函數(shù)及一些特殊形式
這篇文章主要介紹了解析C++中多層派生時(shí)的構(gòu)造函數(shù)及一些特殊形式,特殊形式主要針對(duì)基類(lèi)和子對(duì)象類(lèi)型的構(gòu)造函數(shù)內(nèi)容,需要的朋友可以參考下2015-09-09C++指針作為函數(shù)的參數(shù)進(jìn)行傳遞時(shí)需要注意的一些問(wèn)題
當(dāng)指針作為函數(shù)的參數(shù)進(jìn)行傳遞的時(shí)候,本質(zhì)上還是進(jìn)行的“值傳遞”,也就是復(fù)制了一個(gè)新的指向該地址的指針變量2013-10-10C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之雙鏈表&循環(huán)鏈表&靜態(tài)鏈表詳解
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)中雙鏈表&循環(huán)鏈表&靜態(tài)鏈表的原理與使用,文中的示例代碼講解詳細(xì),感興趣的可以了解一下2022-09-09利用C語(yǔ)言玩轉(zhuǎn)魔方陣實(shí)例教程
這篇文章主要給大家介紹了關(guān)于利用C語(yǔ)言玩轉(zhuǎn)魔方陣的相關(guān)資料,文中詳細(xì)介紹了關(guān)于奇數(shù)魔方陣和4N 魔方陣的實(shí)現(xiàn)方法,通過(guò)示例代碼讓大家更好的參考學(xué)習(xí),需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-11-11C++使用郵件槽實(shí)現(xiàn)ShellCode跨進(jìn)程傳輸
在計(jì)算機(jī)安全領(lǐng)域,進(jìn)程間通信(IPC)一直是一個(gè)備受關(guān)注的話題,在本文中,我們將探討如何使用Windows郵件槽(Mailslot)實(shí)現(xiàn)ShellCode的跨進(jìn)程傳輸,需要的可以參考下2023-12-12