C語(yǔ)言學(xué)生信息管理系統(tǒng)
本文實(shí)例為大家分享了C語(yǔ)言學(xué)生信息管理系統(tǒng)的具體代碼,供大家參考,具體內(nèi)容如下
列表內(nèi)容
系統(tǒng)以菜單方式工作
學(xué)生信息錄入功能(學(xué)生信息用文件保存)—輸入
學(xué)生信息瀏覽功能——輸出
查詢、排序功能——算法
1、按學(xué)號(hào)查詢
2、按姓名查詢
學(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)查詢:\n");
printf("2.按姓名查詢:\n");
printf("請(qǐng)輸入查詢方式:");
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)// 以可寫的方式打開當(dāng)前目錄下的.txt
{
printf("不能打開此文件,請(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"); //以只讀方式打開當(dāng)前目錄下的.txt
if(fp==NULL)
{
printf("不存在打開文件\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"); //以只讀方式打開當(dāng)前目錄下的.txt
if(FP==NULL)
{
printf("無(wú)法打開文件\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ì)基類和子對(duì)象類型的構(gòu)造函數(shù)內(nèi)容,需要的朋友可以參考下2015-09-09
C++指針作為函數(shù)的參數(shù)進(jìn)行傳遞時(shí)需要注意的一些問(wèn)題
當(dāng)指針作為函數(shù)的參數(shù)進(jìn)行傳遞的時(shí)候,本質(zhì)上還是進(jìn)行的“值傳遞”,也就是復(fù)制了一個(gè)新的指向該地址的指針變量2013-10-10
C語(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-11
C++使用郵件槽實(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

