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

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

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

本文實例為大家分享了C語言學生信息管理系統(tǒng)的具體代碼,供大家參考,具體內容如下

列表內容

系統(tǒng)以菜單方式工作
學生信息錄入功能(學生信息用文件保存)—輸入
學生信息瀏覽功能——輸出
查詢、排序功能——算法
1、按學號查詢
2、按姓名查詢
學生信息的刪除與修改
界面簡單明了;
有一定的容錯能力,比如輸入的成績不在0~100之間,就提示不合法,要求重新
輸入;
用鏈表的方式實現(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]; //學號 
  char sex;//性別 (w代表女生m代表男生) 
  int age;//年齡 
  int score;//成績 
}stu; 
typedef struct LNode 
{ 
  stu data; 
  struct LNode *next; 
}LinkList; 

char nam[100];//名字 
char nu[100];//學號 
char s;//性別 
int ag;//年齡 
int sc;//成績 

void welocome()//登陸界面 
{ 
  system("color b1"); 
  printf("````````````````````````````````````````````````````````````````````````````````"); 
  printf("\n"); 
  printf("\n"); 
  printf("\n"); 
  printf(" *********************** 歡迎登錄學生信息管理平臺 ************************* \n"); 
  printf("\n"); 
  printf("\n"); 
  printf("\n"); 
  printf("````````````````````````````````````````````````````````````````````````````````"); 
} 

void menu()//功能菜單 
{ 
  system("color e3"); 
  printf("  |________________________________________________|\n"); 
  printf("  |                        |\n"); 
  printf("  |        學生信息管理系統(tǒng)        |\n"); 
  printf("  |                        |\n"); 
  printf("  |        0、退出系統(tǒng)           |\n"); 
  printf("  |        1、增加學生信息         |\n"); 
  printf("  |        2、刪除學生信息         |\n"); 
  printf("  |        3、修改學生信息         |\n"); 
  printf("  |        4、查找學生的信息        |\n"); 
  printf("  |        5、按照學生成績排序       |\n"); 
  printf("  |        6、瀏覽全部學生信息       |\n"); 
  printf("  |        7、保存學生信息到文件      |\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é)點 
{ 
  LinkList *q=NULL; 
  q=L; 
  p->next=q->next; 
  q->next=p; 
} 

void addstu(LinkList *&L)//增加新的學生 
{ 
  system("color f2"); 
  printf("請輸入學生的信息:\n"); 
  printf("學號:"); 
  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("總成績:");  
    scanf("%d",&sc); 
    while(sc>100||sc<0){
      printf("輸入有誤,請重新輸入\n");
      scanf("%d",&sc); 
    }
    p->data.score=sc; 
    ListInsert(L,p); 

  } 
} 

void deletestu(LinkList *L)//刪除學生 
{ 
  system("color f4"); 
  printf("請輸入您要刪除的學生的學號:"); 
  scanf("%s",nu); 
  //判斷 
  LinkList *p,*pre; 
  if(L->next==NULL) 
  { 
    printf("還沒有學生信息,請增加學生信息\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("刪除學生成功\n"); 
         break; 
     } 
     pre=p; 
     p=p->next; 
  } 
  if(judge==0) 
    printf("該生不存在\n"); 
} 

void changestu(LinkList *L)//改變學生信息 
{ 
  int judge=1; 
  system("color e4"); 
  printf("請輸入您要修改學生的學號:\n"); 
  scanf("%s",nu); 
  LinkList *q=L->next; 
  while(q!=NULL ) 
  { 
    if(strcmp(q->data.num,nu)==0) 
    { 
      judge=1; 
      printf("請輸入您要修改的信息選項:1.姓名 2. 總成績 3.年齡  \n"); 
      int n; 
      scanf("%d",&n); 
      switch(n) 
      { 
      case 1: 
        printf("請輸入您要修改的名字:"); 
        scanf("%s",nam); 
        printf("修改的名字為:%s\n",nam); 
        strcpy(q->data.name,nam);
        printf("修改名字成功!\n"); 
        break; 
      case 2: 
        printf("請輸入您要修改的總成績"); 
        scanf("%d",&sc); 
        printf("修改的總成績?yōu)椋?d\n",sc); 
        q->data.score=sc; 
        printf("修改總成績成功!\n"); 

        break; 
      case 3: 
        printf("請輸入您要修改的年齡:"); 
        scanf("%d",&ag); 
        printf("修改的年齡為:%d\n",ag); 
        q->data.age=ag; 
        printf("修改年齡成功!\n"); 
        break; 
      default : 
        printf("請輸入正確的選項\n"); 
        break; 
      } 
    } 
    q=q->next; 
  } 
  if(judge==0) 
  { 
   printf("該生不存在\n"); 
  } 
} 

void findstu(LinkList *L)//按學號或者姓名查找學生并輸出該生信息 
{ 
  int flag;
  system("color b1"); 
  printf("1.按學號查詢:\n");
  printf("2.按姓名查詢:\n");
  printf("請輸入查詢方式:");
  scanf("%d",&flag); 
  if(flag==1){
    printf("請輸入該生學號:"); 
    scanf("%s",nu); 
    //判斷 
    LinkList *q=L->next; 
    while(q!=NULL ) 
    { 
      if(strcmp(q->data.num,nu)==0) 
      { 
        printf("姓名:%s\n",q->data.name); 
        printf("學號:%s\n",q->data.num); 
        printf("性別:%c\n",q->data.sex); 
        printf("年齡:%d\n",q->data.age); 
        printf("總成績:%d\n",q->data.score); 
        break; 
      } 
       q=q->next; 
    } 
    if(q==NULL) 
      printf("該生不存在\n"); 
  }else{
    printf("請輸入該生姓名:");
    scanf("%s",nam); 
    LinkList *q=L->next; 
    while(q!=NULL ) 
    { 
      if(strcmp(q->data.name,nam)==0) 
      { 
        printf("姓名:%s\n",q->data.name); 
        printf("學號:%s\n",q->data.num); 
        printf("性別:%c\n",q->data.sex); 
        printf("年齡:%d\n",q->data.age); 
        printf("總成績:%d\n",q->data.score); 
        break; 
      } 
       q=q->next; 
    } 
    if(q==NULL) 
      printf("該生不存在\n"); 
  }
} 

void display(LinkList *&L)//瀏覽全部學生信息 
{ 
  LinkList *q=L->next; 
  if(q==NULL) 
  { 
    printf("還沒有學生信息,請增加學生信息\n"); 
    return; 
  } 
  while(q) 
  { 
    system("color c0"); 
    printf(" 學號:%s 名字:%s 年齡:%d 性別:%c 總成績:%d \n",q->data.num,q->data.name,q->data.age,q->data.sex, 
   q->data.score); 
    q=q->next; 
  } 
} 

void paixu(LinkList *L)//按成績排序排序 并輸出排序后的結果 
{ 
  system("color f9"); 
  LinkList *q,*p,*r=L->next; 
  //判斷 
  if(r==NULL) 
  { 
    printf("還沒有學生信息,請增加學生信息\n"); 
    return; 
  } 
  while(r) //兩層循環(huán)完成排序 
  { 
     p=r; 
     q=r->next; 
     LinkList *tmp;//用于排序時暫存節(jié)點 
     InitList(tmp); 
     while(q) 
     { 
       if(q->data.score > p->data.score) 
       { 
        /*先復制q結點信息到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; 
        /*再復制p結點信息到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; 
        /*最后復制exchange結點信息到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("排序后的學生信息是:\n"); 
  display(L); 
} 

void saveStuDentFile(LinkList * &L)//保存學生信息到文件 
{ 
  FILE *fp; 
  LinkList *p=L->next; 
  if((fp=fopen("student.txt","w"))==NULL)// 以可寫的方式打開當前目錄下的.txt 
  { 
    printf("不能打開此文件,請按任意鍵退出\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) //運行前把文件內容讀取到電腦內存 
{ 
  FILE *fp; 
  fp=fopen("student.txt","rb"); //以只讀方式打開當前目錄下的.txt 
  if(fp==NULL) 
  { 
    printf("不存在打開文件\n"); 
    exit(0);          //終止程序 
  } 
  int i=0; 
  while(!feof(fp)) 
  { 
    char nu[100];//學號 
    char nam[100];//名字 
    char s;//性別 
    int ag;//年齡 
    int sc;//成績 
    fscanf(fp," %s %s %c %d %d",nu,nam,&s,&ag,&sc);
    i++; 
  } 
  fclose(fp); 
  FILE *FP; 
  FP=fopen("student.txt","rb"); //以只讀方式打開當前目錄下的.txt 
  if(FP==NULL) 
  { 
    printf("無法打開文件\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);//把后者的內容拷貝到前者中 
      strcpy(n->data.name,nam);//把后者的內容拷貝到前者中 
      n->data.sex=s; 
      n->data.age=ag; 
      n->data.score=sc; 
      ListInsert(L,n);//插入新的節(jié)點 
      n=n->next; 
      if(j==b) 
        break; 
      j++; 
    } 
  fclose(FP);  //關閉文件 
} 

int main() 
{ 
  system("cls");//清屏 
  welocome();//登陸界面 
  Sleep(3000);//延緩3秒 
  LinkList *L; 
  InitList(L); 
  readStuDentput (L);//運行前把文件內容讀取到電腦 
  int a; 
  int choose; 
  while(1) 
  { 
    printf("請輸入您要選擇的功能鍵:\n"); 
    menu();//功能菜單 
    scanf("%d",&choose); 
    switch(choose) 
    { 
    case 0://退出 
      printf("謝謝使用!歡迎下次光臨"); 
      exit(0); 
    case 1://增加學生信息 
      addstu(L);//增加新的學生 
      break; 
    case 2://刪除所有學生信息 
      deletestu(L);//刪除學生 
      break; 
    case 3://改變個學生的信息 
      changestu(L);//改變學生信息 
      break; 
    case 4://查找某個學生的信息 
      findstu(L);//按學號查找學生并輸出該生信息 
      break; 

    case 5:// 對學生成績進行排序 
      paixu(L); 
      break; 
    case 6://輸出所有學生的信息 
      display(L); 
      break; 
    case 7://保存學生信息到文件 
      saveStuDentFile(L); 
      break; 
    default: 
      printf("請輸入正確的選擇\n"); 
      break; 
    } 
  } 
} 

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 解析C++中多層派生時的構造函數及一些特殊形式

    解析C++中多層派生時的構造函數及一些特殊形式

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

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

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

    C++小知識:用++i替代i++

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

    C語言常用占位符的使用小結

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

    C++指針作為函數的參數進行傳遞時需要注意的一些問題

    當指針作為函數的參數進行傳遞的時候,本質上還是進行的“值傳遞”,也就是復制了一個新的指向該地址的指針變量
    2013-10-10
  • C語言枚舉與聯(lián)合體深入詳解

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

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

    C語言數據結構之雙鏈表&循環(huán)鏈表&靜態(tài)鏈表詳解

    這篇文章主要為大家詳細介紹了C語言數據結構中雙鏈表&循環(huán)鏈表&靜態(tài)鏈表的原理與使用,文中的示例代碼講解詳細,感興趣的可以了解一下
    2022-09-09
  • 利用C語言玩轉魔方陣實例教程

    利用C語言玩轉魔方陣實例教程

    這篇文章主要給大家介紹了關于利用C語言玩轉魔方陣的相關資料,文中詳細介紹了關于奇數魔方陣和4N 魔方陣的實現(xiàn)方法,通過示例代碼讓大家更好的參考學習,需要的朋友們下面隨著小編來一起學習學習吧。
    2017-11-11
  • Dijkstra最短路徑算法實現(xiàn)代碼

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

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

    C++使用郵件槽實現(xiàn)ShellCode跨進程傳輸

    在計算機安全領域,進程間通信(IPC)一直是一個備受關注的話題,在本文中,我們將探討如何使用Windows郵件槽(Mailslot)實現(xiàn)ShellCode的跨進程傳輸,需要的可以參考下
    2023-12-12

最新評論