亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C語(yǔ)言學(xué)生信息管理系統(tǒng)

 更新時(shí)間:2020年12月23日 09:37:08   作者:Combatting  
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言學(xué)生信息管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(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ù)及一些特殊形式

    這篇文章主要介紹了解析C++中多層派生時(shí)的構(gòu)造函數(shù)及一些特殊形式,特殊形式主要針對(duì)基類(lèi)和子對(duì)象類(lèi)型的構(gòu)造函數(shù)內(nèi)容,需要的朋友可以參考下
    2015-09-09
  • C++如何刪除map容器中指定值的元素詳解

    C++如何刪除map容器中指定值的元素詳解

    map容器是C++ STL中的重要一員,刪除map容器中value為指定元素的問(wèn)題是我們經(jīng)常與遇到的一個(gè)問(wèn)題,下面這篇文章主要給大家介紹了關(guān)于利用C++如何刪除map容器中指定值的元素的相關(guān)資料,需要的朋友可以參考借鑒,下面來(lái)一起看看吧。
    2017-06-06
  • C++小知識(shí):用++i替代i++

    C++小知識(shí):用++i替代i++

    今天小編就為大家分享一篇關(guān)于C++小知識(shí):用++i替代i++,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-01-01
  • C語(yǔ)言常用占位符的使用小結(jié)

    C語(yǔ)言常用占位符的使用小結(jié)

    占位符是一種用于格式化輸出的特殊字符,通常用于 printf() 等輸出函數(shù)中,本文主要介紹了C語(yǔ)言常用占位符的使用小結(jié),非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2023-05-05
  • C++指針作為函數(shù)的參數(shù)進(jìn)行傳遞時(shí)需要注意的一些問(wèn)題

    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ǔ)言枚舉與聯(lián)合體深入詳解

    C語(yǔ)言枚舉與聯(lián)合體深入詳解

    枚舉顧名思義就是把所有的可能性列舉出來(lái),像一個(gè)星期分為七天我們就可以使用枚舉,聯(lián)合體是由關(guān)鍵字union和標(biāo)簽定義的,和枚舉是一樣的定義方式,不一樣的是,一個(gè)聯(lián)合體只有一塊內(nèi)存空間,什么意思呢,就相當(dāng)于只開(kāi)辟最大的變量的內(nèi)存,其他的變量都在那個(gè)變量占據(jù)空間
    2022-09-09
  • C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之雙鏈表&循環(huán)鏈表&靜態(tài)鏈表詳解

    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í)例教程

    利用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
  • Dijkstra最短路徑算法實(shí)現(xiàn)代碼

    Dijkstra最短路徑算法實(shí)現(xiàn)代碼

    這篇文章主要介紹了Dijkstra最短路徑算法實(shí)現(xiàn)代碼,有需要的朋友可以參考一下
    2013-12-12
  • C++使用郵件槽實(shí)現(xiàn)ShellCode跨進(jìn)程傳輸

    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

最新評(píng)論