C語言實現(xiàn)班級檔案管理系統(tǒng)課程設(shè)計
更新時間:2022年05月30日 13:32:27 作者:Fredinando
這篇文章主要為大家詳細介紹了C語言實現(xiàn)班級檔案管理系統(tǒng)課程設(shè)計,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了C語言班級檔案管理系統(tǒng)的具體代碼,供大家參考,具體內(nèi)容如下
做的挺長時間的課程設(shè)計,當作參考吧
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define N 20
struct student
{
long num;
char name[20];
char sex[10];
int age;
char bz[40];
struct student *next;
};
int i,j,n,num2,num3,age3,k,m;
char name3[20],sex3[20],bz3[20],ch;
FILE *fp;
int login() //登陸函數(shù)
{
char key[20];
printf("\t ********************請輸入系統(tǒng)密碼********************\n");
do
{
scanf("%s",key);
if((strcmp("a",key))==0)
{
printf("\t password correct ,welcome !\n");
return 1; //當密碼正確時,返回1,進入系統(tǒng)
}
printf("\t password incorrect,please input again!\n");
}while(key!=1);//當返回值不為1時,重新輸入密碼,直到輸入真確為止
system("cls");
}
int menu() //菜單
{
int c;
printf("\t\t**********歡迎進入通訊客戶端!************\n\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.退出系統(tǒng)——————————|\n");
printf("\t\t請選擇您要進行的功能(0~7) ");
scanf("%d",&c);
return c;
}
struct student *creat() //錄入信息函數(shù)
{
struct student *head,*p1,*p2;
n=0;
p1=p2=(struct student *)malloc(sizeof(struct student));
head=NULL;
printf("請輸入學(xué)生信息學(xué)號,姓名,性別,年齡,備注(鍵入學(xué)生學(xué)號為0時結(jié)束)\n");
while(1) //為1表真,p2->next不為0;
{
scanf("%d",&p1->num);
if(p1->num==0) //判斷學(xué)生的學(xué)號是否為0,如果為0則停止輸入數(shù)據(jù);
{
break;
}
scanf("%s%s%d%s",p1->name,p1->sex,&p1->age,p1->bz);
n=n+1;
if(n==1)
{
head=p1;
}
else
{
p2->next=p1;
}
p2=p1;
p1=(struct student *)malloc(sizeof(struct student));
}
p2->next=NULL;
system("cls");
return(head);
}
void print(struct student *head) //輸出信息函數(shù)
{
struct student *p;
printf("\t\t這里有 %d 個學(xué)生的數(shù)據(jù)信息\n",n);
p=head;
if(head!=NULL)
{
do
{
printf("\t\t學(xué)號:%d\t姓名:%s\t性別:%s\t年齡:%d\t備注:%s\n",p->num,p->name,p->sex,p->age,p->bz);
p=p->next;
}while(p!=NULL);
}
else
{
return 0;
}
printf("\n");
}
int save(struct student *p) //保存信息函數(shù)
{
FILE *fp;
if((fp=fopen("keshe.txt","wb"))==NULL)
{
printf("open file fail\n");
}
fp=fopen("stud","wb");
do
{
fwrite(p,sizeof(struct student),1,fp);
p=p->next;
}while(p!=NULL);
printf("\t\t\t保存成功!\n");
fclose(fp);
return 0;
}
struct student *del(struct student *head)
{
struct student *p1,*p2;
printf("\t\t請輸入要刪除學(xué)生的學(xué)號\n");
scanf("%d",&num2);
p1=head;
if(head->num==num2)
{
head=head->next;
free(p1);
n--;
}
else
{
p2=head;
while(p2->num!=num2&&p2->next!=NULL)
{
p1=p2;
p2=p2->next;
}
if(p2->num==num2)
{
p1->next=p2->next;
n--;
}
printf("delete:%ld\n",num2);
}
return (head);
}
int mod(struct student *head); //修改信息函數(shù)
struct student *modify(struct student *head)
{
if(login()==0)
{
return 0;
}
else
{
struct student *p1;
j=0;
p1=(struct student *)malloc(sizeof(struct student));
printf("\t\t\t請輸入你要更改的學(xué)號\n");
scanf("%d",&num2);
printf("\t\t\t學(xué)號\n");
scanf("%d",&num3);
printf("\t\t\t姓名\n");
scanf("%s",name3);
printf("\t\t\t性別\n");
scanf("%s",sex3);
printf("\t\t\t年齡\n");
scanf("%d",&age3);
printf("\t\t\t備注\n");
scanf("%s",bz3);
p1=head;
if(head->num==num2)
{
head->num=num3;
strcpy(head->name,name3);
strcpy(head->sex,sex3);
head->age=age3;
strcpy(head->bz,bz3);
j=1;
}
else
{
p1=head->next;
if(p1!=NULL)
{
while(p1->num!=num2)
{
p1=p1->next;
}
p1->num=num2;
strcpy(p1->name,name3);
strcpy(p1->sex,sex3);
p1->age=age3;
strcpy(p1->bz,bz3);
j=1;
}
}
if(j==0)
{
printf("\t\t\t更改失敗\n");
}
else
{
printf("\t\t\t更改成功\n");
}
}
system("cls");
mod(head);
}
int mod(struct student *head)
{
printf("\t\t\t請選擇\n");
printf("\t\t\t1:按學(xué)號修改學(xué)生信息\n");
printf("\t\t\t2:輸出修改后的學(xué)生信息\n");
printf("\t\t\t3:返回主菜單\n");
scanf("%d",&m);
switch(m)
{
case 1:head=modify(head);break;
case 2:print(head);break;
case 3:menu();break;
default:printf("\t\t\tinput error!\n");
mod(head);
}
}
int find(struct student *head);
int find1(struct student *head) //以學(xué)號方式查找
{
struct student *p1;
p1=(struct student *)malloc(sizeof(struct student));
printf("\t\t\t請輸入你要查詢的學(xué)生學(xué)號\n");
scanf("%d",&num2);
p1=head;
while(p1!=NULL)
{
if(p1->num==num2)
{
k=1;
printf("\t\t\t學(xué)號:%d\t姓名:%s\t性別:%s\t年齡:%d\t備注:%s\n\n",p1->num,p1->name,p1->sex,p1->age,p1->bz);
break;
}
p1=p1->next;
}
if(k==0)
{
printf("\t\t\t沒有查詢到您要找的學(xué)生信息\n\n");
}
else
{
printf("\t\t\t這就是您要找的學(xué)生信息\n\n");
}
find(head);
}
int find2(struct student *head) //以姓名方式查找
{
struct student *p1;
p1=(struct student *)malloc(sizeof(struct student));
printf("\t\t\t請輸入您要查詢的學(xué)生姓名\n");
scanf("%s",name3);
p1=head;
while(p1!=NULL)
{
if((strcmp(p1->name,name3))==0)
{
k=1;
printf("\t\t\t學(xué)號:%d\t姓名:%s\t性別:%s\t年齡:%d\t備注:%s\n\n",p1->num,p1->name,p1->sex,p1->age,p1->bz);
break;
}
p1=p1->next;
}
if(k==0)
{
printf("\t\t\t沒有找到該學(xué)生信息\n\n");
}
else
{
printf("\t\t\t這就是您要查詢的學(xué)生信息\n\n");
}
find(head);
}
int find3(struct student *head) //以性別方式查找
{
struct student *p1;
p1=(struct student *)malloc(sizeof(struct student));
printf("\t\t\t請輸入你要查詢的學(xué)生的性別\n");
scanf("%s",sex3);
p1=head;
while(p1!=NULL)
{
if((strcmp(p1->sex,sex3))==0)
{
k=1;
printf("\t\t\t學(xué)號:%d\t姓名:%s\t性別:%s\t年齡:%d\t備注:%s\n\n",p1->num,p1->name,p1->sex,p1->age,p1->bz);
break;
}
p1=p1->next;
}
if(k==0)
{
printf("\t\t\t沒有找到該學(xué)生信息\n\n");
}
else
{
printf("\t\t\t這就是您要查詢的學(xué)生的信息\n\n");
}
find(head);
}
int find4(struct student *head) //以年齡方式查找
{
struct student *p1;
p1=(struct student *)malloc(sizeof(struct student));
printf("\t\t\t請輸入您要查詢的學(xué)生的年齡\n");
scanf("%d",&age3);
p1=head;
while(p1!=NULL)
{
if(p1->age==age3)
{
k=1;
printf("\t\t\t學(xué)號:%d\t姓名:%s\t性別:%s\t年齡:%d\t備注:%s\n\n",p1->num,p1->name,p1->sex,p1->age,p1->bz);
break;
}
p1=p1->next;
}
if(k==0)
{
printf("\t\t\t沒有找到該學(xué)生的信息\n\n");
}
else
{
printf("\t\t\t這就是您要找的學(xué)生的信息\n\n");
}
find(head);
}
int find(struct student *head)
{
printf("\t\t\t請選擇您要查詢學(xué)生信息的方式\n");
printf("\t\t\t1:按學(xué)生學(xué)號查詢\n");
printf("\t\t\t2:按學(xué)生姓名查詢\n");
printf("\t\t\t3:按學(xué)生性別查詢\n");
printf("\t\t\t4:按學(xué)生年齡查詢\n");
printf("\t\t\t5:返回主菜單\n");
scanf("%d",&m);
switch(m)
{
case 1:find1(head);break;
case 2:find2(head);break;
case 3:find3(head);break;
case 4:find4(head);break;
case 5:system("cls");menu();break;
default:printf("\t\t\tinput error,please input again\n");
}
}
int main() //主函數(shù)
{
struct student *phead;
if(login()==0)
{
return 0;
}
printf("\n");
while(1)
{
switch(menu())
{
case 1:system("cls");phead=creat();break;
case 2:system("cls");print(phead);break;
case 3:system("cls");save(phead);break;
case 4:system("cls");phead=del(phead);break;
case 5:system("cls");mod(phead);break;
case 6:system("cls");find(phead);break;
case 7:system("cls");printf("\t\t\t歡迎使用,再見!\n");return 0;
default:printf("\t\t\t輸入有錯,請重新輸入\n");
}
}
}更多學(xué)習(xí)資料請關(guān)注專題《管理系統(tǒng)開發(fā)》。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
json格式解析和libjson的用法介紹(關(guān)于cjson的使用方法)
下面小編就為大家?guī)硪黄猨son格式解析和libjson的用法介紹(關(guān)于cjson的使用方法)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-12-12
Matlab利用遺傳算法GA求解非連續(xù)函數(shù)問題詳解
遺傳算法起源于對生物系統(tǒng)所進行的計算機模擬研究。其本質(zhì)是一種高效、并行、全局搜索的方法,能在搜索過程中自動獲取和積累有關(guān)搜索空間的知識,并自適應(yīng)地控制搜索過程以求得最佳解。本文將利用其求解非連續(xù)函數(shù)問題,需要的可以參考一下2022-09-09
C語言實現(xiàn)文件內(nèi)容按行隨機排列的算法示例
這篇文章主要介紹了C語言實現(xiàn)文件內(nèi)容按行隨機排列的算法,涉及C語言字符串、數(shù)組遍歷與隨機數(shù)相關(guān)算法實現(xiàn)技巧,需要的朋友可以參考下2017-09-09

