欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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)文章

  • C/C++實現(xiàn)全排列算法的示例代碼

    C/C++實現(xiàn)全排列算法的示例代碼

    本文主要介紹了C/C++實現(xiàn)全排列算法的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-06-06
  • QT中QColorDialog開發(fā)實例

    QT中QColorDialog開發(fā)實例

    QColorDialog是Qt框架中用于選擇顏色的對話框類,本文主要介紹了QT中QColorDialog開發(fā)實例,具有一定的參考價值,感興趣的可以了解一下
    2023-11-11
  • json格式解析和libjson的用法介紹(關(guān)于cjson的使用方法)

    json格式解析和libjson的用法介紹(關(guān)于cjson的使用方法)

    下面小編就為大家?guī)硪黄猨son格式解析和libjson的用法介紹(關(guān)于cjson的使用方法)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-12-12
  • C++?Cmake使用詳細教程(看這一篇就夠了!)

    C++?Cmake使用詳細教程(看這一篇就夠了!)

    CMake是一個比make更高級的編譯配置工具,它可以根據(jù)不同平臺、不同的編譯器,生成相應(yīng)的Makefile或者vcproj項目,下面這篇文章主要給大家介紹了關(guān)于C++?Cmake使用的相關(guān)資料,需要的朋友可以參考下
    2023-03-03
  • C++并查集算法簡單詳解

    C++并查集算法簡單詳解

    大家好,本篇文章主要講的是C++并查集算法簡單詳解,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-02-02
  • c++中堆棧及創(chuàng)建對象示例代碼

    c++中堆棧及創(chuàng)建對象示例代碼

    這篇文章主要給大家詳細介紹了c++如何實現(xiàn)堆棧及創(chuàng)建對象,文中先進行了簡單的介紹,而后給出了詳細的示例代碼及注釋,相信對大家的理解和學(xué)習(xí)很有幫助,有需要的朋友們下面跟著小編一起來學(xué)習(xí)學(xué)習(xí)吧。
    2016-12-12
  • Matlab利用遺傳算法GA求解非連續(xù)函數(shù)問題詳解

    Matlab利用遺傳算法GA求解非連續(xù)函數(shù)問題詳解

    遺傳算法起源于對生物系統(tǒng)所進行的計算機模擬研究。其本質(zhì)是一種高效、并行、全局搜索的方法,能在搜索過程中自動獲取和積累有關(guān)搜索空間的知識,并自適應(yīng)地控制搜索過程以求得最佳解。本文將利用其求解非連續(xù)函數(shù)問題,需要的可以參考一下
    2022-09-09
  • C語言基于EasyX庫實現(xiàn)有圖形界面鐘表

    C語言基于EasyX庫實現(xiàn)有圖形界面鐘表

    這篇文章主要介紹了C語言基于EasyX庫實現(xiàn)有圖形界面鐘表,直線轉(zhuǎn)動端點計算,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Qt實現(xiàn)拖動單個控件移動的示例代碼

    Qt實現(xiàn)拖動單個控件移動的示例代碼

    做慣了靜態(tài)圖,今天來搞一搞動態(tài)圖吧!本文將利用Qt實現(xiàn)拖動單個控件移動效果,文中的示例代碼講解詳細,感興趣的可以動手嘗試一下
    2022-06-06
  • C語言實現(xiàn)文件內(nèi)容按行隨機排列的算法示例

    C語言實現(xiàn)文件內(nèi)容按行隨機排列的算法示例

    這篇文章主要介紹了C語言實現(xiàn)文件內(nèi)容按行隨機排列的算法,涉及C語言字符串、數(shù)組遍歷與隨機數(shù)相關(guān)算法實現(xiàn)技巧,需要的朋友可以參考下
    2017-09-09

最新評論