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

基于C語言實現(xiàn)學生成績管理系統(tǒng)

 更新時間:2018年01月15日 12:01:07   作者:想飛的孤獨少年  
這篇文章主要介紹了基于C語言實現(xiàn)學生成績管理系統(tǒng),具有一定的參考價值,感興趣的小伙伴們可以參考一下

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

這里只貼代碼,具體介紹省略。

#include <stdio.h>
#include <io.h>
#include <conio.h>
#include <stdlib.h>
#include <string.h>
#define MAX 200

struct student
{
 char no[10]; // 學號 
 char name[50]; // 姓名
 float score[3];  // 分數(shù)
 float math;
 float eng;
 float phy;
};
struct data
{
 int count; // 當前學生數(shù)組中學生的個數(shù)
 struct student stu[MAX]; // 學生數(shù)組
}dd;

// 顯示主菜單
void menu()
{
 system("cls");//清屏 
 printf("\n\n\n");
 printf("\t\t\t *******************************\n");
 printf("\t\t\t        \n");
 printf("\t\t\t  學生成績管理系統(tǒng)  \n");
 printf("\t\t\t        \n");
 printf("\t\t\t [1] 查看所有學生信息  \n");
 printf("\t\t\t [2] 輸入學生記錄  \n");
 printf("\t\t\t [3] 刪除學生記錄   \n");
 printf("\t\t\t [4] 修改學生記錄  \n");
 printf("\t\t\t [5] 查詢學生成績(學號)  \n");
 printf("\t\t\t [6] 查詢成學生績(姓名)  \n");
 printf("\t\t\t [7] 查看成績排序(學號)  \n");
 printf("\t\t\t [0] 退出     \n");
 printf("\t\t\t        \n");
}

// 等待用戶按回車后回到主菜單
void to_menu()
{
 char c1,c2;
 printf("\n\n\n按回車鍵返回主菜單...");
 scanf("%c%c",&c1,&c2);//第一個字符吸收上次的確認回車鍵 
 menu();
}
//統(tǒng)計信息
void ren()
{
 int A=0,B=0,C=0,D=0,E=0,s;
 int i;

 for(i=0;i<dd.count;i++)
 {
  s=(int)(dd.stu[i].math/10);
  switch(s)
  {
   case 10:
   case 9:
    A++;
    break;
   case 8:
    B++;
    break;
   case 7:
    C++;
    break;
   case 6:
    D++;
    break;
   default :
    E++;
    break;
  }
 }

 printf("總人數(shù):%d\n",dd.count); 
 printf("獲得“優(yōu)秀”的人數(shù):%d\n",A);
 printf("獲得“良”的人數(shù):%d\n",B);
 printf("獲得“中”的人數(shù):%d\n",C);
 printf("獲得“及格”的人數(shù):%d\n",D);
 printf("不及格的人數(shù):%d\n",E);

}

// 查看所有學生信息
void view_data()
{
 int i;
 printf("學號\t姓名\t數(shù)學\t英語\t物理");
 printf("\n-------------------------------------------------------------------\n");
 for(i=0;i<dd.count;i++)
  printf("%s\t%s\t%-7.1f\t%-7.1f\t%-7.1f\n",dd.stu[i].no,dd.stu[i].name,dd.stu[i].math,dd.stu[i].eng,dd.stu[i].phy);
 printf("\n-------------------------------------------------------------------\n");
 ren();
}


// 將數(shù)據(jù)從結構體數(shù)組保存到文件中
void save_data()
{
 FILE *fp;//文件指針 
 int i,k;
 k = dd.count; //其實k沒有什么實際的意義,直接在fwrite里使用&dd.count就可以了。
 fp=fopen("D:\\data.txt","w");//文件存儲位置:當前文件夾 
 fwrite(&k,sizeof(int),1,fp);
 for(i=0;i<dd.count;i++)
  fwrite(&dd.stu[i],sizeof(struct student),1,fp);
 fclose(fp);
}

// 輸入學生記錄
void add_data()
{
 int b;
 int k = dd.count;
 while(k<MAX)
 {
  printf("請輸入學生學號:"); scanf("%s",dd.stu[k].no);
  printf("請輸入學生姓名:"); scanf("%s",dd.stu[k].name);
  printf("請輸入數(shù)學成績:"); scanf("%f",&dd.stu[k].math);
  printf("請輸入英語成績:"); scanf("%f",&dd.stu[k].eng);
  printf("請輸入物理成績:"); scanf("%f",&dd.stu[k].phy);

  dd.count++; //需要提前置0,在主函數(shù)中。
  k = dd.count;
  printf("\n\n繼續(xù)添加學生信息[1-yes 0-no]:");
  scanf("%d",&b);
  if(b==0) break;
 }
 save_data();
}

// 將數(shù)據(jù)從文件讀到結構體數(shù)組中
void read_data()
{
 FILE *fp;
 int i,k;

 k=0;
 if((fp=fopen("D:\\data.txt","r"))==NULL) // 如果文件不存在
 {
  dd.count = 0;
 }
 else
 {
  fread(&k,sizeof(int),1,fp);
  dd.count = k;
  for(i=0;i<k;i++)
  {
   fread(&dd.stu[i],sizeof(struct student),1,fp);
  }
  fclose(fp);
 }
}

// 刪除學生記錄
void delete_data()
{
 int i,k;
 char no[10];
 printf("\n請輸入要刪除學生的學號:");
 scanf("%s",no);
 k = -1;
 for(i=0;i<dd.count;i++)
 {
  if(strcmp(dd.stu[i].no,no)==0)
  {
   k = i;
   break;
  }
 }
 if(k==-1)
 {
  printf("\n\n沒有找到該學生(學號-%s)!",no);
 }
 else
 {
  //你沒有寫刪除的操作啊
  for(i=k; i<dd.count-1; i++) //將后面的數(shù)據(jù)前移一位
   dd.stu[i] = dd.stu[i+1];
  memset(&dd.stu[dd.count-1],0,sizeof(struct student)); //將dd.stu[dd.count-1]數(shù)據(jù)置0
  dd.count--;

  save_data();
  printf("\n\n刪除學生(學號-%s)記錄成功!",no);
 }
}

// 修改學生記錄
void edit_data()
{
 int i,k;
 char no[10],name[50];
 printf("\n請輸入要修改學生的學號:");
 scanf("%s",no);
 k=-1;
 for(i=0;i<dd.count;i++)
 {
  if(strcmp(dd.stu[i].no,no)==0)
  {
   k=i;
   break;
  }
 }
 if(k==-1)
 {
  printf("\n\n沒有找到該學生(學號-%s)!",no);
 }
 else
 {
  printf("\n請輸入學生數(shù)據(jù):");
  printf("\n姓名");
  printf("\n--------------------------------------------------------------------\n");
  scanf("%s",name);
  strcpy(dd.stu[k].name,name);
  save_data();
  printf("\n\n修改學生記錄(學號-%s)成功!",no);
 }
}

// 查詢學生成績(學號)
void query_data_no()
{
 int i,k;
 char no[10];
 printf("\n請輸入要查詢學生的學號:");
 scanf("%s",no);
 k=-1;
 for(i=0;i<dd.count;i++)
 {
  if(strcmp(dd.stu[i].no,no)==0)
  {
   printf("\n\n學號\t姓名\t數(shù)學\t英語\t物理");
   printf("\n-----------------------------------------------------------------\n");
   k=i;
   printf("%s\t%s\t%-7.1f\t%-7.1f\t%-7.1f\n",dd.stu[i].no,dd.stu[i].name,dd.stu[i].math,dd.stu[i].eng,dd.stu[i].phy);
   break; // 學號應該是唯一的,找到了一個就代表以后的沒有了。
  }
 }
 if(k==-1)
 {
  printf("\n\n沒有找到該學生(學號-%s)!",no);
 }
}

// 查詢學生成績(姓名)
void query_data_name()
{
 int i,k;
 char name[10];
 printf("\n請輸入要查詢學生的姓名:");
 scanf("%s",name);
 k=-1;
 for(i=0;i<dd.count;i++)
 {
  if(strcmp(dd.stu[i].name,name)==0)
  {
   printf("\n\n學號\t姓名\t數(shù)學\t英語\t物理");
   printf("\n-----------------------------------------------------------------\n");

   k=i;
   printf("%s\t%s\t%-7.1f\t%-7.1f\t%-7.1f\n",dd.stu[i].no,dd.stu[i].name,dd.stu[i].math,dd.stu[i].eng,dd.stu[i].phy);
   break;
  }
 }
 if(k==-1)
 {
  printf("\n\n沒有找到該學生(姓名-%s)!",name);
 }
}

// 排序(學號)
void sort_data_no(struct data Buff)
{
 int i;
 int j;
 int k;
 int h;
 struct student temp;
 FILE *fp;
 if((fp=fopen("D:\\data.txt","w+"))==NULL)
 {
  printf("cannot open file!\n");
  exit(0);
 }
 printf("請輸入要查詢的科目:1-數(shù)學,2-英語,3-物理:");
 scanf("%d",&k);

 switch(k)
 {
  case 1:
   for(i=0; i<Buff.count-1; i++)
    for(j=i+1; j<Buff.count; j++)
    if(Buff.stu[i].math > Buff.stu[j].math)
    {
     temp=Buff.stu[i];
     Buff.stu[i]=Buff.stu[j];
     Buff.stu[j]=temp;
    }
   printf("名次\t學號\t 姓名\t數(shù)學\n");
   for(i=0; i<Buff.count; i++)
    printf("%d\t%s\t%s\t%-7.1f\n",i+1,Buff.stu[i].no,Buff.stu[i].name,Buff.stu[i].math);
   break;
  case 2:
   for(i=0; i<Buff.count-1; i++)
    for(j=i+1; j<Buff.count; j++)
    if(Buff.stu[i].eng > Buff.stu[j].eng)
    {
     temp=Buff.stu[i];
     Buff.stu[i]=Buff.stu[j];
     Buff.stu[j]=temp;
    }
   printf("名次\t學號\t 姓名\t英語\n");
   for(i=0; i<Buff.count; i++)
    printf("%d\t%s\t%s\t%-7.1f\n",i+1,Buff.stu[i].no,Buff.stu[i].name,Buff.stu[i].eng);
   break;
  case 3:
   for(i=0; i<Buff.count-1; i++)
    for(j=i+1; j<Buff.count; j++)
    if(Buff.stu[i].phy > Buff.stu[j].phy)
    {
     temp=Buff.stu[i];
     Buff.stu[i]=Buff.stu[j];
     Buff.stu[j]=temp;
    }
   printf("名次\t學號\t 姓名\t物理\n");
   for(i=0; i<Buff.count; i++)
    printf("%d\t%s\t%s\t%-7.1f\n",i+1,Buff.stu[i].no,Buff.stu[i].name,Buff.stu[i].phy);
   break;
  default :
   printf("輸入錯誤!");
   exit(0);
 }

 printf("請按任意鍵繼續(xù)....");
 getch();

 fclose(fp);
}

// 主函數(shù)
int main(void)
{
 int fun;
 dd.count = 0;
 read_data();
 menu();
 while(1)
 {
  printf("請輸入功能號[0-7]:");//這里不需要什么&fun,
  scanf("%d",&fun);
  switch(fun)
  {
   case 1: view_data();break;  // 查看所有學生信息 
   case 2: add_data(); break;  // 輸入學生記錄 
   case 3: delete_data();break;  // 刪除學生記錄
   case 4: edit_data();break; // 修改學生記錄
   case 5: query_data_no();break; // 查詢學生成績(學號)
   case 6: query_data_name();break; // 查詢成學生績(姓名) 
   case 7: sort_data_no(dd); break; // 查看成績排序(學號) //直接將結構體dd發(fā)送過去就可以了
   case 0: break;     // 退出
  }
  if(fun==0) break; 
  to_menu();
 }

 return 0;
}

更多學習資料請關注專題《管理系統(tǒng)開發(fā)》。

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

相關文章

  • MATLAB中subplot函數(shù)的語法與使用實例

    MATLAB中subplot函數(shù)的語法與使用實例

    subplot()是將多個圖畫到一個平面上的工具,下面這篇文章主要給大家介紹了關于MATLAB中subplot函數(shù)的語法與使用的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-08-08
  • C++各種數(shù)據(jù)類型所占內存大小詳解

    C++各種數(shù)據(jù)類型所占內存大小詳解

    這篇文章主要介紹了C++各種數(shù)據(jù)類型所占內存大小,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • C++實現(xiàn)五子棋小游戲

    C++實現(xiàn)五子棋小游戲

    這篇文章主要為大家詳細介紹了C++實現(xiàn)五子棋小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • C語言 structural body結構體詳解用法

    C語言 structural body結構體詳解用法

    C 數(shù)組允許定義可存儲相同類型數(shù)據(jù)項的變量,結構是 C 編程中另一種用戶自定義的可用的數(shù)據(jù)類型,它允許您存儲不同類型的數(shù)據(jù)項,結構用于表示一條記錄,假設您想要跟蹤圖書館中書本的動態(tài),您可能需要跟蹤每本書的下列屬性
    2021-10-10
  • C語言代碼實現(xiàn)推箱子小游戲

    C語言代碼實現(xiàn)推箱子小游戲

    這篇文章主要為大家詳細介紹了C語言代碼實現(xiàn)推箱子小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • linux下C/C++學生信息管理系統(tǒng)

    linux下C/C++學生信息管理系統(tǒng)

    這篇文章主要為大家詳細介紹了linux下c/c++學生信息管理系統(tǒng),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • 詳解C++ 多態(tài)的兩種形式(靜態(tài)、動態(tài))

    詳解C++ 多態(tài)的兩種形式(靜態(tài)、動態(tài))

    這篇文章主要介紹了C++ 多態(tài)的兩種形式,幫助大家更好的理解和學習c++,感興趣的朋友可以了解下
    2020-08-08
  • C++數(shù)據(jù)結構與算法之哈夫曼樹的實現(xiàn)方法

    C++數(shù)據(jù)結構與算法之哈夫曼樹的實現(xiàn)方法

    這篇文章主要介紹了C++數(shù)據(jù)結構與算法之哈夫曼樹的實現(xiàn)方法,簡單說明了哈夫曼樹的原理,并結合具體實例形式分析了C++實現(xiàn)哈夫曼樹的相關操作技巧,需要的朋友可以參考下
    2017-11-11
  • C語言 strftime 格式化顯示日期時間的實現(xiàn)

    C語言 strftime 格式化顯示日期時間的實現(xiàn)

    下面小編就為大家?guī)硪黄狢語言 strftime 格式化顯示日期時間的實現(xiàn)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-12-12
  • C++設置超時時間的簡單實現(xiàn)方法

    C++設置超時時間的簡單實現(xiàn)方法

    這篇文章主要介紹了C++設置超時時間的簡單實現(xiàn)方法,涉及系統(tǒng)函數(shù)setsockopt對套接口的操作,具有一定的實用價值,需要的朋友可以參考下
    2014-10-10

最新評論