码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • ★C语言期末课程设计★——学生成绩管理系统(完整项目+源代码+详细注释)


     学生成绩管理系统

     

    目录

     学生成绩管理系统

    一、描述

    二、设计目的

    三、系统分析

    四、主要功能

    五、系统流程图

    六、运行和调式

            1、主界面

            2、录入学生成绩信息

            3、查找学生信息

            4、删除学生成绩信息 

            5、修改学生成绩信息

            6、插入学生信息

            7、按总分排序并保存到文本中

            8、学生人数

    七、程序代码

    八、心得体会

    九、其他C/C++期末课程设计系统(完整项目+完全开源)

    十、附载/下载地址

    注意

    C&C++期末课程设计

    C语言期末课程设计


    一、描述

            大家好!我是小浝仔,今天给大家分享C语言期末课程设计——学生成绩管理系统,这个程序是用C语言程序编写的,运行环境为VisualC++6.0,实现了录入学生成绩信息、查找学生成绩信息、删除学生成绩信息、修改学生成绩信息、插入学生成绩信息、按总分排序并保存到文件中、学生人数功能等等,是学习C++语言程序很好的参考资料,本系统在命令行窗口运行,没有可视化界面,没有用到MFC类库,如果朋友们用来学习或做C++语言期末课程设计作业一定是可以的,我来共享给大家一些哦!!!要是觉得好的话,记得给个三连!!!亲测有效哦!!!

     本项目下载地址:(解压可直接运行)

    C语言课程设计——学生成绩管理系统.zip_学生信息管理系统c语言程序设计-C/C++文档类资源-CSDN文库https://download.csdn.net/download/m0_46843484/26808452?spm=1001.2014.3001.5503

    二、设计目的

            通过课程设计使学生综合使用所学过的C语言程序设计知识,掌握结构化程序设计的基本思路和方法,在所掌握的基本知识和技能的基础上,进一步提高自学能力和查找资料的能力,解决一定程度的复杂的结构化程序设计问题,加深对所学知识的理解与掌握,增强学生我们利用自己所学知识解决实际问题的能力,为以后的程序开发打下基础。

    三、系统分析

            随着科学技术的不断发展,对人们的工作水平要求也越来越高,然而计算机就成了帮助人们解决这个问题的工具,熟练的运用计算机,它能为人们解决许多工.作上的难题。对与一个管理人员来说,快而迅速的了解各种信息是很关键的。使用计算机在C语言环境下编写相关的管理系统就能达到对相关信息的录入、显示;对记录的查询极其修改等目的。基于同样的C语言环境,对其提供的头文件*h的不同组合,能为我们解决许许多多的问题,因此,用它来编写成绩管理管理系统是可行的。

    四、主要功能

            1、数据的录入:如录入学生的基本信息,以及该学生选修课程的基本信息;
            2、数据的修改:如修改指定学号、或者指定姓名的学生信息,或者修改其选修课程信息;
            3、数据的插入:插入某个学生信息;
            4、数据的查询:如按学号查询、按姓名查询等:
            5、数据的删除:如删除指定学号、或者指定姓名的学生及其选修课程信息;
            6、总成绩的计算:计算每个学生各门功课的总成绩;
            7、按总分排序并保存到文本中。

    五、系统流程图

    六、运行和调式

            1、主界面

            2、录入学生成绩信息

            3、查找学生信息

            4、删除学生成绩信息 

            5、修改学生成绩信息

            6、插入学生信息

            7、按总分排序并保存到文本中

            8、学生人数

    七、程序代码

    1. #include<stdio.h>
    2. #include<stdlib.h>
    3. #include<conio.h>
    4. #include<dos.h>
    5. #include<string.h>
    6. #define LEN sizeof(struct student)
    7. #define FORMAT "%-8d%-15s%-12.1lf%-12.1lf%-12.1lf%-12.1lf\n"
    8. #define DATA stu[i].num,stu[i].name,stu[i].elec,stu[i].expe,stu[i].requ,stu[i].sum
    9. /* 【小浝仔】CSDN:https://blog.csdn.net/m0_46843484?spm=1011.2124.3001.5343*/
    10. struct student/*定义学生成绩结构体*/
    11. { int num;/*学号*/
    12. char name[15];/*姓名*/
    13. double elec;/*选修课*/
    14. double expe;/*实验课*/
    15. double requ;/*必修课*/
    16. double sum;/*总分*/
    17. };
    18. struct student stu[50];/*定义结构体数组*/
    19. void in();/*录入学生成绩信息*/
    20. void show();/*显示学生信息*/
    21. void order();/*按总分排序*/
    22. void del();/*删除学生成绩信息*/
    23. void modify();/*修改学生成绩信息*/
    24. void menu();/*主菜单*/
    25. void insert();/*插入学生信息*/
    26. void total();/*计算总人数*/
    27. void search();/*查找学生信息*/
    28. void main()/*主函数*/
    29. { int n;
    30. menu();
    31. scanf("%d",&n);/*输入选择功能的编号*/
    32. while(n)
    33. { switch(n)
    34. { case 1: in();break;
    35. case 2: search();break;
    36. case 3: del();break;
    37. case 4: modify();break;
    38. case 5: insert();break;
    39. case 6: order();break;
    40. case 7: total();break;
    41. default:break;
    42. }
    43. getch();
    44. menu();/*执行完功能再次显示菜单界面*/
    45. scanf("%d",&n);
    46. }
    47. }
    48. void in()/*录入学生信息*/
    49. { int i,m=0;/*m是记录的条数*/
    50. char ch[2];
    51. FILE *fp;/*定义文件指针*/
    52. if((fp=fopen("data.txt","a+"))==NULL)/*打开指定文件*/
    53. { printf("can not open\n");return;}
    54. while(!feof(fp)) {
    55. if(fread(&stu[m] ,LEN,1,fp)==1)
    56. m++;/*统计当前记录条数*/
    57. }
    58. fclose(fp);
    59. if(m==0)
    60. printf("No record!\n");
    61. else
    62. {
    63. system("cls");
    64. show();/*调用show函数,显示原有信息*/
    65. }
    66. if((fp=fopen("data.txt","wb"))==NULL)
    67. { printf("can not open\n");return;}
    68. for(i=0;i<m;i++) fwrite(&stu[i] ,LEN,1,fp);/*向指定的磁盘文件写入信息*/
    69. printf("please input(y/n):");
    70. scanf("%s",ch);
    71. while(strcmp(ch,"Y")==0||strcmp(ch,"y")==0)/*判断是否要录入新信息*/
    72. {
    73. printf("学号:");scanf("%d",&stu[m].num);/*输入学生学号*/
    74. for(i=0;i<m;i++)
    75. if(stu[i].num==stu[m].num)
    76. {
    77. printf("the number is existing,press any to continue!");
    78. getch();
    79. fclose(fp);
    80. return;
    81. }
    82. printf("姓名:");scanf("%s",stu[m].name);/*输入学生姓名*/
    83. printf("选修课成绩:");scanf("%lf",&stu[m].elec);/*输入选修课成绩*/
    84. printf("实验课成绩:");scanf("%lf",&stu[m].expe);/*输入实验课成绩*/
    85. printf("必修课成绩:");scanf("%lf",&stu[m].requ);/*输入必修课成绩*/
    86. stu[m].sum=stu[m].elec+stu[m].expe+stu[m].requ;/*计算出总成绩*/
    87. if(fwrite(&stu[m],LEN,1,fp)!=1)/*将新录入的信息写入指定的磁盘文件*/
    88. { printf("保存失败!"); getch(); }
    89. else { printf("%s 保存成功!\n",stu[m].name);m++;}
    90. printf("是否继续?(y/n):");/*询问是否继续*/
    91. scanf("%s",ch);
    92. }
    93. fclose(fp);
    94. printf("OK!\n");
    95. }
    96. void show()
    97. { FILE *fp;
    98. int i,m=0;
    99. fp=fopen("data.txt","rb");
    100. while(!feof(fp))
    101. {
    102. if(fread(&stu[m] ,LEN,1,fp)==1)
    103. m++;
    104. }
    105. fclose(fp);
    106. printf("学号 姓名 选修课 实验课 必修课 合计\t\n");
    107. for(i=0;i<m;i++)
    108. {
    109. printf(FORMAT,DATA);/*将信息按指定格式打印*/
    110. }
    111. }
    112. void menu()/*自定义函数实现菜单功能*/
    113. {
    114. system("cls");
    115. printf("\n\n\n\n\n");
    116. printf("\t\t|---------------------STUDENT-------------------|\n");
    117. printf("\t\t|\t 0. 退出 |\n");
    118. printf("\t\t|\t 1. 录入学生成绩信息 |\n");
    119. printf("\t\t|\t 2. 查找学生信息 |\n");
    120. printf("\t\t|\t 3. 删除学生成绩信息 |\n");
    121. printf("\t\t|\t 4. 修改学生成绩信息 |\n");
    122. printf("\t\t|\t 5. 插入学生信息 |\n");
    123. printf("\t\t|\t 6. 按总分排序 |\n");
    124. printf("\t\t|\t 7. 学生人数 |\n");
    125. printf("\t\t|-----------------------------------------------|\n\n");
    126. printf("\t\t\t选择(0-7):");
    127. }
    128. void order()/*自定义排序函数*/
    129. { FILE *fp;
    130. struct student t;
    131. int i=0,j=0,m=0;
    132. if((fp=fopen("data.txt","r"))==NULL)
    133. {
    134. printf("can not open!\n");
    135. return;
    136. }
    137. while(!feof(fp))
    138. if(fread(&stu[m] ,LEN,1,fp)==1)
    139. m++;
    140. fclose(fp);
    141. if(m==0)
    142. {
    143. printf("no record!\n");
    144. return;
    145. }
    146. if((fp=fopen("data.txt","wb"))==NULL)
    147. {
    148. printf("can not open\n");
    149. return;}
    150. for(i=0;i<m-1;i++)
    151. for(j=i+1;j<m;j++)/*双重循环实现成绩比较并交换*/
    152. if(stu[i].sum<stu[j].sum)
    153. { t=stu[i];stu[i]=stu[j];stu[j]=t;}
    154. if((fp=fopen("data.txt","wb"))==NULL)
    155. { printf("can not open\n");return;}
    156. for(i=0;i<m;i++)/*将重新排好序的内容重新写入指定的磁盘文件中*/
    157. if(fwrite(&stu[i] ,LEN,1,fp)!=1)
    158. {
    159. printf("%s can not save!\n");
    160. getch();
    161. }
    162. fclose(fp);
    163. printf("save successfully\n");
    164. }
    165. void del()/*自定义删除函数*/
    166. {FILE *fp;
    167. int snum,i,j,m=0;
    168. char ch[2];
    169. if((fp=fopen("data.txt","r+"))==NULL)
    170. { printf("can not open\n");return;}
    171. while(!feof(fp)) if(fread(&stu[m],LEN,1,fp)==1) m++;
    172. fclose(fp);
    173. if(m==0)
    174. {
    175. printf("no record!\n");
    176. return;
    177. }
    178. printf("请输入学号:");
    179. scanf("%d",&snum);
    180. for(i=0;i<m;i++)
    181. if(snum==stu[i].num)
    182. break;
    183. printf("find the student,delete?(y/n)");
    184. scanf("%s",ch);
    185. if(strcmp(ch,"Y")==0||strcmp(ch,"y")==0)/*判断是否要进行删除*/
    186. for(j=i;j<m;j++)
    187. stu[j]=stu[j+1];/*将后一个记录移到前一个记录的位置*/
    188. m--;/*记录的总个数减1*/
    189. if((fp=fopen("data.txt","wb"))==NULL)
    190. { printf("can not open\n");return;}
    191. for(j=0;j<m;j++)/*将更改后的记录重新写入指定的磁盘文件中*/
    192. if(fwrite(&stu[j] ,LEN,1,fp)!=1)
    193. { printf("不能保存!\n");
    194. getch();}
    195. fclose(fp);
    196. printf("删除成功!\n");
    197. }
    198. void search()/*自定义查找函数*/
    199. { FILE *fp;
    200. int snum,i,m=0;
    201. char ch[2];
    202. if((fp=fopen("data.txt","rb"))==NULL)
    203. { printf("can not open\n");return;}
    204. while(!feof(fp)) if(fread(&stu[m],LEN,1,fp)==1) m++;
    205. fclose(fp);
    206. if(m==0) {printf("no record!\n");return;}
    207. printf("please input the number:");
    208. scanf("%d",&snum);
    209. for(i=0;i<m;i++)
    210. if(snum==stu[i].num)/*查找输入的学号是否在记录中*/
    211. { printf("find the student,show?(y/n)");
    212. scanf("%s",ch);
    213. if(strcmp(ch,"Y")==0||strcmp(ch,"y")==0)
    214. {
    215. printf("学号 姓名 选修课 实验课 必修课 合计\t\n");
    216. printf(FORMAT,DATA);/*将查找出的结果按指定格式输出*/
    217. break;
    218. }
    219. }
    220. if(i==m) printf("can not find the student!\n");/*未找到要查找的信息*/
    221. }
    222. void modify()/*自定义修改函数*/
    223. { FILE *fp;
    224. int i,j,m=0,snum;
    225. if((fp=fopen("data.txt","r+"))==NULL)
    226. { printf("can not open\n");return;}
    227. while(!feof(fp))
    228. if(fread(&stu[m],LEN,1,fp)==1) m++;
    229. if(m==0) {printf("no record!\n");
    230. fclose(fp);
    231. return;
    232. }
    233. printf("please input the number of the student which do you want to modify!\n");
    234. scanf("%d",&snum);
    235. for(i=0;i<m;i++)
    236. if(snum==stu[i].num)/*检索记录中是否有要修改的信息*/
    237. break;
    238. printf("find the student!you can modify!\n");
    239. printf("name:\n");
    240. scanf("%s",stu[i].name);/*输入名字*/
    241. printf("\nelective:");
    242. scanf("%lf",&stu[i].elec);/*输入选修课成绩*/
    243. printf("\nexperiment:");
    244. scanf("%lf",&stu[i].expe);/*输入实验课成绩*/
    245. printf("\nrequired course:");
    246. scanf("%lf",&stu[i].requ);/*输入必修课成绩*/
    247. stu[i].sum=stu[i].elec+stu[i].expe+stu[i].requ;
    248. if((fp=fopen("data.txt","wb"))==NULL)
    249. { printf("can not open\n");return;}
    250. for(j=0;j<m;j++)/*将新修改的信息写入指定的磁盘文件中*/
    251. if(fwrite(&stu[j] ,LEN,1,fp)!=1)
    252. { printf("保存失败!"); getch(); }
    253. fclose(fp);
    254. }
    255. void insert()/*自定义插入函数*/
    256. { FILE *fp;
    257. int i,j,k,m=0,snum;
    258. if((fp=fopen("data.txt","r+"))==NULL)
    259. { printf("can not open\n");return;}
    260. while(!feof(fp))
    261. if(fread(&stu[m],LEN,1,fp)==1) m++;
    262. if(m==0) {printf("no record!\n");
    263. fclose(fp);
    264. return;
    265. }
    266. printf("please input position where do you want to insert!(input the number)\n");
    267. scanf("%d",&snum);/*输入要插入的位置*/
    268. for(i=0;i<m;i++)
    269. if(snum==stu[i].num)
    270. break;
    271. for(j=m-1;j>i;j--)
    272. stu[j+1]=stu[j];/*从最后一条记录开始均向后移一位*/
    273. printf("now please input the new information.\n");
    274. printf("number:");
    275. scanf("%d",&stu[i+1].num);
    276. for(k=0;k<m;k++)
    277. if(stu[k].num==stu[i+1].num)
    278. {
    279. printf("the number is existing,press any to continue!");
    280. getch();
    281. fclose(fp);
    282. return;
    283. }
    284. printf("name:\n");
    285. scanf("%s",stu[i+1].name);
    286. printf("\nelective:");
    287. scanf("%lf",&stu[i+1].elec);
    288. printf("\nexperiment:");
    289. scanf("%lf",&stu[i+1].expe);
    290. printf("\nrequired course:");
    291. scanf("%lf",&stu[i+1].requ);
    292. stu[i+1].sum=stu[i+1].elec+stu[i+1].expe+stu[i+1].requ;
    293. if((fp=fopen("data.txt","wb"))==NULL)
    294. { printf("can not open\n");return;}
    295. for(k=0;k<=m;k++)
    296. if(fwrite(&stu[k] ,LEN,1,fp)!=1)/*将修改后的记录写入磁盘文件中*/
    297. { printf("can not save!"); getch(); }
    298. fclose(fp);
    299. }
    300. void total()
    301. { FILE *fp;
    302. int m=0;
    303. if((fp=fopen("data.txt","r+"))==NULL)
    304. { printf("can not open\n");return;}
    305. while(!feof(fp))
    306. if(fread(&stu[m],LEN,1,fp)==1)
    307. m++;/*统计记录个数即学生个数*/
    308. if(m==0) {printf("no record!\n");fclose(fp);return;}
    309. printf("the class are %d students!\n",m);/*将统计的个数输出*/
    310. fclose(fp);
    311. }

    八、心得体会

            通过本次C程序课程设计,我觉得对自己提高很大:克服了的偷懒的毛病,这在我以后的学习和工作中的心理定位与调节有很大的帮助。我感受到了编程是一项非常烦琐周密的活动,他不但需要一个人周密的思考问题的能力,处理问题的能力,还需要有足够的耐心和严谨治学的作风,来不得半点马虎。

            通过本次课程设计,我初步学会了论文设计的基本方法,学会了怎样去借鉴别人的方法和经验,知道如何去查找资料和整合处理这些资料的能力,这为以后的大学毕业设计论文打下了一个初步的基础使我收益最人的是享受到了一种成功的喜悦,在这两个星期之中从开始的确定论文题目,然后是上网和上图书馆查找资料,编写C语言原程序,然后是进行编译,这个环节是一个非常痛苦和艰难的,常常会因为一小点的错误而在编译失败与再次修改的漫漫循环之路中,但失败的越多,对人的考验就越多,在编译运行成功之后的享受成功的喜悦也就越多,另外在调试程序的过程中不断的思考和运用已经学到的知识,这对于自己是有很大的提高的。

            由于所学的知识不多,自己的编程经验不足,仍存在一些错误,按现有的知识水平有些东西暂时还无法解决,还有待于在以后的学习中不断提高和改进!

    九、其他C/C++期末课程设计系统(完整项目+完全开源)

    ★C++语言期末课程设计★——图书借阅系统(完整项目+源代码+详细注释)

    ★C/C++语言期末课程设计★——万年历显示系统(详细报告+源代码+详细注释)

    ★C语言期末课程设计★——教师工资管理系统(详细报告+源代码+详细注释)

    ★C语言期末课程设计★——成绩管理系统(源代码+详细注释)

    【C语言期末课程设计】——超市管理系统(开源)

    ★C/C++期末课程设计★—☆产品入库管理操作系统☆【开源+详细注释】

    【C&C++期末课程设计】——职工工作量统计系统(源代码+详细注释)

    ​​​​​​【C&C++期末课程设计】——职工资源管理系统(源代码+详细注释)

    C&C++期末课程设计——个人收支管理系统(一)【源代码+详细注释】

    C&C++期末课程设计——学生成绩管理源代码

    C&C++期末课程设计——图书管理系统源代码

    C++期末课程设计——宾馆客房管理系统(详细报告+源代码+详细注释)(另附加“25+”C++&&C语言期末课程设计系统下载地址)

    C&C++期末课程设计——产品管理系统(源代码+详细注释)

    十、附载/下载地址

    注意

    下面附载了“25+”C++&&C语言期末课程设计下载地址(超详细),每个系统的简介都详细介绍了本系统的实现功能,可以根据功能查找自己所需要的。

    C&C++期末课程设计

    C&C++——文件成绩(源代码).zip

    C&amp;C++课程设计——图书管理系统.zip

    C&C++课程设计——学生成绩管理系统.zip

    C/C++课程设计——职工工作量统计系统(源代码、注释).zip

    C&C++课程设计——班级学生档案管理系统源代码(源代码+注释).zip

    C&C++期末课程设计——KTV歌曲管理系统(源代码+详细注释).zip

    C&amp;C++期末课程设计——产品信息管理系统(源代码+详细注释).zip

     C&C++期末课程设计——个人收支管理系统(源代码+详细注释).zip

     C&C++期末课程设计——职工资源管理系统(源代码+详细注释).zip

    C&C++期末课程设计——个人收支管理系统(二)(源代码+详细注释).zip

    C语言期末课程设计

    C语言课程设计——教工工资管理系统(源代码+课程设计+详细注释).zip

    C语言课程设计——成绩管理系统源程序.zip

    C语言课程设计——超市管理系统(源代码+详细注释).zip

    C语言课程设计——火车票订票管理系统(源代码+详细注释).zip

    C语言课程设计——商品销售系统(源代码+详细注释).zip

    C语言课程设计——通讯录管理系统(源代码+详细注释).zip

    C语言课程设计——图书管理系统(源代码+详细注释).zip

    C++语言课程设计——图书借阅系统(源代码+详细注释).zip

    C语言课程设计——万年历系统(源代码+详细注释).zip

    C语言课程设计——文本编辑器系统(源代码+详细注释).zip

    C语言课程设计——学生成绩管理系统.zip

     C语言课程设计——学生成绩管理系统(源代码+详细注释).zip

    C语言课程设计——学生信息系统(源代码+详细注释).zip

    C语言课程设计——做的绘图板系统(源代码+详细注释).zip

    有问题或意见,请及时联系我: 

    CSDN:小浝仔_CSDN博客https://blog.csdn.net/m0_46843484?spm=1000.2115.3001.5343

    版权声明: 本博客所有文章除特别声明外,著作权归作者所有。转载请注明出处!

  • 相关阅读:
    [4G/5G/6G专题基础-155]: 5G 3GPP高精确室内定位原理、AI方案概述
    一文看懂推荐系统:排序12:xDeepFM模型,并不是对DeepFM的改进,而是对DCN的改进哦
    开发知识点-golang
    设置Unity URP管线中的渲染开关
    【预测模型】基于径向基神经网络实现数据回归预测附matlab代码
    Spring Boot全面总结(超详细,建议收藏)
    抖音开发对接之订单取消消息
    springcloud05——Zookeeper实现支付微服务
    LeetCode710. 黑名单中的随机数.Random Pick with Blacklist [hash映射][前缀和][二分]
    openjudge_2.5基本算法之搜索_1998:寻找Nemo
  • 原文地址:https://blog.csdn.net/m0_46843484/article/details/125313474
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号