码迷,mamicode.com
首页 > 编程语言 > 详细

C语言课程设计之学生信息管理系统

时间:2014-11-30 06:08:16      阅读:508      评论:0      收藏:0      [点我收藏+]

标签:io   ar   color   os   使用   sp   for   文件   on   

  1. #include"stdio.h"        //标准的输入输出函数文件头部说明  
  2. #include"math.h"              // 数学函数头部说明  
  3. #include"string.h"  
  4. #include"stdlib.h"    //通过该函数头部里的函数,改变控制台的背景和颜色  
  5. #include"windows.h"    //头文件声明,下文用到了改变控制台的宽度和高度  
  6. #define M 100            //宏定义说明  
  7. struct student{    //结构体定义并声明  
  8.  char name[25];     //姓名  
  9.  char num[25];     //学号  
  10.  char credit[20];    //身份证号  
  11.  char native[35];    //籍贯  
  12.  char tel[25];     //手机号  
  13.  int special;     //专业  
  14.  int banji;      //班级  
  15.  int math,yy,wl,cyy,pe;   //数学、英语、物理、C语言、体育  
  16.  double ave;};     //平均分  
  17. //****************************************函数的声明********************************************  
  18. void input(struct student stu[M]);     //输入函数  
  19. void output(struct student stu[M]);     //各类用户自定义函数的声明  
  20. void lookfor(struct student stu[M]);    //查询函数  
  21. void modify(struct student stu[M]);     //修改函数  
  22. void order(struct student stu[M]);     //排序函数  
  23. void delete_student(struct student stu[M]);   //删除函数  
  24. void xuehao(struct student stu[M]);       
  25. void xingming(struct student stu[M]);  
  26. void fileread(struct student stu[M]);  
  27. void filewrite(struct student stu[M]);  
  28. void yanshi(char *p);        //延时函数说明  
  29. //**********************************************************************************************  
  30. int count=0;  
  31. struct student t;  
  32. int main()   
  33. {  
  34.     int choice,sum;  
  35.     struct student stu[M];         
  36.     system("mode con:cols=400 lines=30000");        //调节控制台的宽度和高度  
  37.      system("color 0b");      //调节控制台的背景和字体颜色  
  38. point1:    
  39.     sum=0;  
  40.     yanshi("\t\t\t\t\t\t\t\t\3\3\3\3\3\3\3\3\3\3\3\3\3欢迎你使用学生信息管理系统\3\3\3\3\3\3\3\3\3\3\n");  
  41.     do {  
  42.     printf("\t\t\t\t\t\t\t\t-------------------------------------------------\n");  
  43.     printf("\t\t\t\t\t\t\t\t+       学生信息管理系统            +\n");  
  44.     printf("\t\t\t\t\t\t\t\t-------------------------------------------------\n");  
  45.     printf("\t\t\t\t\t\t\t\t\t\t ***************\n");  
  46.     printf("\t\t\t\t\t\t\t\t\t\t 1、添加学生信息\n");  
  47.     printf("\t\t\t\t\t\t\t\t\t\t 2、浏览学生信息\n");  
  48.     printf("\t\t\t\t\t\t\t\t\t\t 3、查询学生信息\n");  
  49.     printf("\t\t\t\t\t\t\t\t\t\t 4、修改学生信息\n");  
  50.     printf("\t\t\t\t\t\t\t\t\t\t 5、删除学生信息\n");  
  51.     printf("\t\t\t\t\t\t\t\t\t\t 6、排列学生信息\n");   
  52.     printf("\t\t\t\t\t\t\t\t\t\t 7、读取文件学生\n");                  //从文件读取  
  53.     printf("\t\t\t\t\t\t\t\t\t\t 8、保存到文件\n");                    //保存到文件  
  54.     printf("\t\t\t\t\t\t\t\t\t\t 9、退出系统\n");     
  55.     printf("\t\t\t\t\t\t\t\t\t\t ***************\n");   
  56.     printf("请输入你的选择\n");  
  57.     scanf("%d",&choice);  
  58.     fflush(stdin);       //清除输入缓冲区  
  59.     if (choice>9||choice<=0)  
  60.     {  
  61.     sum++;  
  62.     if (sum>=5)  
  63.     {  
  64.     printf("输入错误次数过多,程序将重新开始\n");  
  65.     system("pause");        //程序暂停  
  66.     system("cls");   //清屏语句  
  67.     goto point1;  
  68.     }  
  69.     }  
  70.     switch (choice)       //根据选择,调用不同的函数来完成不同的任务  
  71.     {  
  72.     case 1:input(stu);break;         
  73.     case 2:output(stu);break;  
  74.     case 3:lookfor(stu);break;  
  75.     case 4:modify(stu);break;  
  76.     case 5:delete_student(stu);break;  
  77.     case 6:order(stu);break;  
  78.     case 7:fileread(stu);break;  
  79.     case 8:filewrite(stu);;break;  
  80.     case 9:printf("感谢你使用学生信息管理系统,请关掉程序!!!\n");system("pause");break;  
  81.     default:printf("无效的选择!!!请重新输入!!!\n");break;  
  82.     }  
  83.     }while (choice!=9);  
  84.     printf("the program is over!!!\n");  
  85.      return 0;  
  86. }  
  87. void input(struct student stu[M])      //自定义输入函数  
  88. {  
  89.     int len,size;  
  90.     system("cls");  
  91.     printf("请添加要输入学生的信息\n");  
  92.     do {  
  93.     printf("请输入由11位数字组成的学生学号\n");   //do-while循环应用,提示输入位数为一确定数  
  94.     scanf("%s",&stu[count].num);  
  95.     len=strlen(stu[count].num);  
  96.     }while(len!=11);  
  97.     printf("请输入同学的姓名\n");  
  98.     scanf("%s",stu[count].name);  
  99.     do {  
  100.     printf("请输入由18位数字组成的学生身份证号\n");   //同上  
  101.     scanf("%s",&stu[count].credit);  
  102.     size=strlen(stu[count].credit);  
  103.     }while(size!=18);                                                     
  104.     printf("请输入学生的籍贯\n");  
  105.     scanf("%s",&stu[count].native);  
  106.     printf("请输入学生的手机号码\n");  
  107.     scanf("%s",&stu[count].tel);  
  108.     printf("请输入所需要的专业代号:1、计算机科学 2、通信工程 3、网络工程\n");  //采用如此方法解决了专业输入难问题  
  109.     scanf("%d",&stu[count].special);  
  110.     printf("请输入对应的学生班级号码:1、1301 2、1302 \n");  
  111.     scanf("%d",&stu[count].banji);  
  112.     do {  
  113.     printf("请依次输入不大于100的学生各科成绩\n");  
  114.     scanf("%d%d%d%d%d",&stu[count].math,&stu[count].yy,&stu[count].wl,&stu[count].cyy,&stu[count].pe);  
  115.     }while(stu[count].math>100||stu[count].yy>100||stu[count].wl>100||stu[count].cyy>100||stu[count].pe>100);   //同上同上  
  116.     stu[count].ave=(stu[count].math+stu[count].yy+stu[count].wl+stu[count].cyy+stu[count].pe)/5.0;       //求出平均值  
  117.     count++;  
  118. }  
  119. void output(struct student stu[M])     //自定义输出函数  
  120. {  
  121.     int j;  
  122.     system("cls");  
  123.     if (count==0)  
  124.     {  
  125.     printf("当前已存学生信息为0个\n");  
  126.     return;  
  127.     }  
  128.     for (j=0;j<count;j++)  
  129.     {  
  130.     printf("学号\t\t  姓名\t\t身份证号\t籍贯\t手机号\t\t专业\t\t班级\t数学\t英语\t物理\tC语言\t体育\t平均分\n");  
  131.     for (j=0;j<count;j++){       //for循环控制输出的个数  
  132.     printf("%s\t",stu[j].num);  
  133.     printf("%s\t",stu[j].name);  
  134.     printf("%s\t",stu[j].credit);  
  135.     printf("%s\t",stu[j].native);  
  136.     printf("%s\t",stu[j].tel);  
  137.     if (stu[j].special==1)  
  138.     printf("计算机科学\t");  
  139.     else if (stu[j].special==2)  
  140.     printf("通信工程\t");  
  141.     else  
  142.     printf("网络工程\t");        
  143.     printf("%d\t",stu[j].banji);  
  144.     printf("%d\t",stu[j].math);  
  145.     printf("%d\t",stu[j].yy);  
  146.     printf("%d\t",stu[j].wl);  
  147.     printf("%d\t",stu[j].cyy);  
  148.     printf("%d\t",stu[j].pe);  
  149.     printf("%.1lf\t\n",stu[j].ave);}  
  150.     }  
  151. }  
  152. void lookfor(struct student stu[M])                   //自定义查询学生信息函数  
  153. {  
  154.     int j,flag=0;  
  155.     char xh[25];  
  156.     system("cls");  
  157.     if (count==0)  
  158.     {  
  159.     printf("当前已存学生信息为0个,无法查询!!!\n");  
  160.     return;  
  161.     }  
  162.     else  
  163.     {  
  164.     printf("请输入你想要查看的同学学号\n");  
  165.     scanf("%s",&xh);  
  166.     fflush(stdin);  
  167.     for (j=0;j<count;j++)  
  168.     {  
  169.     if (strcmp(stu[j].num,xh)==0)       //通过字符函数对已存入的学生信息进行比较,找出要查看的学生  
  170.     {  
  171.     printf("学号\t\t姓名\t\t身份证号\t籍贯\t手机号\t\t专业\t\t班级\t数学\t英语\t物理\tC语言\t体育\t平均分\n");  
  172.     printf("%s\t",stu[j].num);  
  173.     printf("%s\t",stu[j].name);  
  174.     printf("%s\t",stu[j].credit);  
  175.     printf("%s\t",stu[j].native);  
  176.     printf("%s\t",stu[j].tel);  
  177.     if (stu[j].special==1)  
  178.     printf("计算机科学\t");  
  179.     else if (stu[j].special==2)  
  180.     printf("通信工程\t");      
  181.     else  
  182.     printf("网络工程\t");  
  183.     printf("%d\t",stu[j].banji);     //考虑一个对齐的因数  
  184.     printf("%d\t",stu[j].math);  
  185.     printf("%d\t",stu[j].yy);  
  186.     printf("%d\t",stu[j].wl);  
  187.     printf("%d\t",stu[j].cyy);  
  188.     printf("%d\t",stu[j].pe);  
  189.     printf("%.1lf\t",stu[j].ave);  
  190.     }  
  191.     }  
  192.     if (j==count)  
  193.     printf("很抱歉,没有你所需要的学生信息\n");  
  194.     }  
  195. }  
  196. void modify(struct student stu[M])    //自定义修改函数  
  197. {  
  198.     int j,flag=0,course;  
  199.     char xh[25];  
  200.     system("cls");  
  201.     if (count==0)  
  202.     {  
  203.     printf("当前已存学生信息为0个,无法修改!!!\n");  
  204.     return;  
  205.     }  
  206.     else  
  207.     {  
  208.     printf("请输入你想要修改的同学学号\n");  
  209.     scanf("%s",&xh);  
  210.     fflush(stdin);  
  211.     for (j=0;j<count;j++)  
  212.     if (strcmp(stu[j].num,xh)==0)        //同上  
  213.     {  
  214.     printf("你确定要修改学生的信息吗???如果不确定的话,请关掉本程序吧!!!\n");  
  215.     printf("选择课程: 1、数学 2、英语 3、物理 4、C语言 5、体育\n");  
  216.     scanf("%d",&course);  
  217.     printf("请输入你想要修改后的学生成绩\n");  
  218.     switch(course)  
  219.     {  
  220.     case 1:scanf("%d",&stu[j].math);break;  
  221.     case 2:scanf("%d",&stu[j].yy);break;        //switch控制语句  
  222.     case 3:scanf("%d",&stu[j].wl);break;  
  223.     case 4:scanf("%d",&stu[j].cyy);break;  
  224.     case 5:scanf("%d",&stu[j].pe);break;  
  225.     default:printf("无效的选择!!!请重新输入!!!\n");break;  
  226.     }   
  227.     }  
  228.     }  
  229. }  
  230. void delete_student(struct student stu[M])        //自定义删除函数  
  231. {  
  232.     int choice;  
  233.     system("cls");  
  234.     if (count==0)  
  235.     {  
  236.     printf("当前已存学生信息为0个,无法删除!!!\n");  
  237.     return;  
  238.     }  
  239.     else  
  240.     {  
  241.     printf("请选择你所要删除的方式:1、学号 2、姓名(如果你的姓名是中文,那么无法删除,请选择学号删除) 3、取消\n");  
  242.     scanf("%d",&choice);  
  243.     switch(choice)            //switch语句对用户要删除的方式进行选择  
  244.     {  
  245.     case 3:return;break;  
  246.     case 2:xingming(stu);break;         //用户自定义函数之间的套用  
  247.     case 1:xuehao(stu);break;  
  248.     default:printf("无效的选择!!!请重新输入!!!\n");break;  
  249.     }  
  250.     }  
  251. }  
  252. void order(struct student stu[M])        //排序函数的定义  
  253. {  
  254.     int j,k,choice,index;  
  255.     system("cls");  
  256.     printf("请输入你想要进行排序的方式(所有排序的方式均是降序)!!!\n");  
  257.     printf("1、数学 2、英语 3、物理 4、C语言 5、体育 6、平均分\n");  
  258.     scanf("%d",&choice);  
  259.     switch (choice)  
  260.     {  
  261.     case 1:for (j=0;j<count;j++)  
  262.     { index=j;   
  263.     for (k=j+1;k<count;k++)  
  264.     if (stu[k].math>stu[index].math)  
  265.     {t=stu[k];stu[k]=stu[index];stu[index]=t;}  
  266.      };break;  
  267.     case 2:for (j=0;j<count;j++)  
  268.      { index=j;   
  269.     for (k=j+1;k<count;k++)  
  270.     if (stu[k].yy>stu[index].yy)  
  271.     {stu[k]=stu[index];}                                //整个为排序部分,采用了所谓的选择排序的方法  
  272.      };break;  
  273.     case 3:for (j=0;j<count;j++)  
  274.      { index=j;   
  275.     for (k=j+1;k<count;k++)  
  276.     if (stu[k].wl>stu[index].wl)  
  277.     {t=stu[k];stu[k]=stu[index];stu[index]=t;}  
  278.      };break;  
  279.     case 4:for (j=0;j<count;j++)  
  280.      { index=j;   
  281.     for (k=j+1;k<count;k++)  
  282.     if (stu[k].cyy>stu[index].cyy)  
  283.     {t=stu[k];stu[k]=stu[index];stu[index]=t;}  
  284.      };break;  
  285.     case 5:for (j=0;j<count;j++)  
  286.      { index=j;   
  287.     for (k=j+1;k<count;k++)  
  288.     if (stu[k].pe>stu[index].pe)  
  289.     {t=stu[k];stu[k]=stu[index];stu[index]=t;}  
  290.      };break;  
  291.     case 6:for (j=0;j<count;j++)  
  292.      { index=j;   
  293.     for (k=j+1;k<count;k++)  
  294.     if (stu[k].ave>stu[index].ave)  
  295.     {t=stu[k];stu[k]=stu[index];stu[index]=t;}   //强制类型转换符号只能用于有操作数,根据赋值运算中的类型转换问题可知  
  296.      };break;  
  297.     default:printf("无效的选择!!!请重新输入!!!\n");break;  
  298.     }  
  299. }  
  300. void xuehao(struct student stu[M])           //自定义通过学号方式删除学生信息函数  
  301. {  
  302.     int j,index=0,k=count;  
  303.     char xh[25];  
  304.     system("cls");  
  305.     printf("请输入你想要删除的同学学号\n");  
  306.     scanf("%s",xh);  
  307.     fflush(stdin);  
  308.     for (j=0;j<count;j++)  
  309.     { if (strcmp(stu[j].num,xh)==0)  
  310.     {     
  311.     for (j=index;j<count;j++)  
  312.     stu[j]=stu[j+1];  
  313.     count--;  
  314.     if (count<k)  
  315.     printf("你已经删除成功\n");  
  316.     }  
  317.     index++;}  
  318.     if (j==count)  
  319.     printf("抱歉!!!没有你所需要删除的学生信息!*_*!\n");  
  320. }  
  321. void xingming(struct student stu[M])           //自定义通过姓名方式删除学生信息函数  
  322. {  
  323.     int flag=0,j,k=count;  
  324.     char xm[25];  
  325.     system("cls");  
  326.     printf("请输入你想要删除的同学姓名\n");  
  327.     scanf("%s",xm);  
  328.     fflush(stdin);  
  329.     for (j=0;j<count;j++)  
  330.     {  
  331.     if (strcmp(stu[j].num,xm)==0)  
  332.     {  
  333.   
  334.     for (j=flag-1;j<count;j++)               
  335.     stu[j]=stu[j+1];  
  336.     count--;  
  337.     if (count<k)  
  338.     printf("你已经删除成功\n");  
  339.     }     
  340.     flag++;}  
  341.     if (j==count)  
  342.     printf("抱歉!!!没有你所需要删除的学生信息!*_*!\n");  
  343. }  
  344. void yanshi(char *p)              //延时函数的定义  
  345. {  
  346.     while (1)  
  347.     {  
  348.     if (*p!=0)  
  349.     printf("%c",*p++);  
  350.     else  
  351.     break;  
  352.     Sleep(100);               //延时控制间断语句  
  353.     }  
  354. }  
  355. void filewrite(struct student stu[M])                   //写入文件函数定义  
  356. {  
  357.     int j=0;  
  358.     char c;  
  359.     FILE *fp;  
  360.     printf("请选择是否要存入已输入的学生信息:‘y‘还是‘n‘???\n");  
  361.     scanf("%c",&c);  
  362.     fflush(stdin);  
  363.     while(c!=‘y‘&&c!=‘n‘){  
  364.     if (c!=‘y‘&&c!=‘n‘)  
  365.     printf("输入错误,请重新输入\n");  
  366.     printf("以下操作将会覆盖已存储的数据,确定请输入‘y‘或‘n‘???\n");  
  367.     scanf("%c",&c);  
  368.     fflush(stdin);  
  369.     }  
  370.     if (c==‘y‘)  
  371.     {  
  372.     if((fp=fopen("d:\\stu.dat","wb"))==NULL)  
  373.     {  
  374.         printf("文件打开错误,程序无法进行\n");  
  375.         exit(0);  
  376.     }  
  377.     for(j=0;j<count;j++)  
  378.       {fwrite(&stu[j],sizeof(struct student),1,fp);  
  379.     }  
  380.     fclose(fp);  
  381.     if(count==0)  
  382.         printf("没有文件,无法保存\n");  
  383.     else  
  384.     printf("数据存储完毕\n");  
  385.     system("pause");  
  386.     }  
  387.     else  
  388.         return;  
  389. }  
  390. void fileread(struct student stu[M])                    //读取文件信息函数定义  
  391. {  
  392.     int j=0;  
  393.     char c;  
  394.     FILE *fp;  
  395.     system("cls");  
  396.     printf("请选择是否要存入已输入的学生信息:‘y‘还是‘n‘???\n");  
  397.     scanf("%c",&c);  
  398.     fflush(stdin);  
  399.     while(c!=‘y‘&&c!=‘n‘){  
  400.     if (c!=‘y‘&&c!=‘n‘)  
  401.     printf("输入错误,请重新输入\n");  
  402.     printf("以下操作将会覆盖已存储的数据,确定请输入‘y‘或‘n‘???\n");  
  403.     scanf("%c",&c);  
  404.     fflush(stdin);  
  405.     }  
  406.     if (c==‘y‘)  
  407.     {  
  408.     if((fp=fopen("d:\\stu.dat","rb"))==NULL)  
  409.     {  
  410.         printf("文件打开错误,程序无法进行\n");  
  411.         exit(0);  
  412.     }  
  413.     fread(&stu[j],sizeof(struct student),1,fp);   
  414.     count=0;  
  415.     count++;  
  416.     j++;  
  417.     while(fread(&stu[j],sizeof(struct student),1,fp))  
  418.     {  
  419.         j++;  
  420.         count++;  
  421.     }  
  422.     fclose(fp);  
  423.     printf("数据读取完毕!!!\n");  
  424.     system("pause");  
  425.     }  
  426.     else  
  427.     return;  

C语言课程设计之学生信息管理系统

标签:io   ar   color   os   使用   sp   for   文件   on   

原文地址:http://www.cnblogs.com/yuyanbian/p/4132284.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!