C语言——课程设计

2024-04-25 12:58
文章标签 语言 课程设计

本文主要是介绍C语言——课程设计,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、实验目的

  1. 了解开发环境
  2. 掌握结构体变量的定义和使用;
  3. 掌握结构体数组的定义和使用;
  4. 掌握文件输入,输出基本方法
  5. 掌握函数用法

二、实验内容

【项目1】完成以下功能的设计。

此学生成绩管理可以实现对学生成绩及基本信息进行创建、添加、删除,对已经存在的学生信息进行查询、排序、统计并保存至文件中。
设学生信息包括:姓名、学号、性别、英语、计算机、高数、平均分。除平均成绩外,其他成绩都为已知。初始同学成绩存放在文本文件datas.dat中。从文件输入学生数据,并打印出每个学生的记录(除平均成绩外)。
数据请自理,如:

数据以文本形式应该存放在datas.dat中

邓文俊			20140023	男	96	64	54	郑芬				20140024	女	69	55	77	李凯		20140026	男	88	51	50	林紫娟		20140039	女	89	64	62	游成松		20140045	男	98	82	68	雷小航		20140050	男	62	92	78	李立红		20140051	女	80	82	79	陈荣		20140052	男	71	98	63	袁春燕		20140053	女	83	81	77	冉灿		20140054	男	53	85	92	周雪莲		20140056	女	62	60	54	张小清		20140063	女	75	52	83	陈梅		20140064	女	89	99	62	郑涵		20140074	男	97	94	65

每个子功能请做成函数进行调用。

设计说明
1、菜单功能:用if else或switch做一个选择性的结构,从而实现输入相应的数字来达成与之对应的功能;反复操作直到输入0退出为止。
2、创建:定义对应的结构体,可用数组或链式结构实现,自由选择不做限定。
3、 新增学生:在适当的位置插入一个新的学生信息。如何插入,在哪里插入均自由选择,自己体会在哪里进行数据操作是高效和方便的。
4、 显示学生信息:显示出所有学生的基本信息。
5、 搜索学生信息:输入想要查看学生的姓名,如果有与之相匹配的就输出,如果没有则输出“没有该生信息”。
6、 删除学生信息:
遍历存储表,输入想删除学生信息的位置,若输入的位置为假,继续向下一个节点遍历,直到与输入的位置相符合。
遍历存储表,输入想删除的学生的学号,若存在该学生则将其删除。
7、 统计学生性别信息:通过学生的性别分别进行统计并输出。
8、 按英语成绩排序:利用冒泡排序方法,将排序结果按英语成绩的降序输出学号及英语成绩列。
9、 退出程序:输入与退出程序相匹配的数字即可。
10、进行添加或删除后的信息要重新写入datas.dat文件中

结构体定义提示:

#define NAME_NUMBER 10
#define ID_NUMBER   9
#define SEX_NUMBER  3
#define SCORE_NUMBER    3
#define MAX_STUDENT_NUMBER 100struct student
{char name[NAME_NUMBER];char id[ID_NUMBER];char sex[SEX_NUMBER];float score[SCORE_NUMBER];float averageSCore;
};
typedef struct student STUDENT;

源代码:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
struct student
{char name[100];int id;char sex[100];float egl;float mat;float com;float ave;
};
typedef struct student STUDENT;STUDENT stu[100];
int getlong(STUDENT stu_[]);//获取当前学生数
int print(STUDENT stu_[]);//显示全部学生信息
int add(int n);//新增学生信息
int reserch();//查询学生信息
int delete1(int n);//删除学生信息方式一
int delete2();//删除学生信息方式二
int sexprint();//统计学生性别
int yingyusort();//按英语成绩排序
int main()
{FILE *fp = fopen("datas.dat", "r+");int i=0;if(fp == NULL){printf("can't read data from the datas.dat!\n");exit(0);}while(fscanf(fp,"%s%d%s%f%f%f",stu[i].name,&stu[i].id,stu[i].sex,&stu[i].egl,&stu[i].mat,&stu[i].com)!=EOF){i++;}printf("导入完成,学生数为:%d\n",getlong(stu));fclose(fp);int choice,n,x;while (1){printf("\n\n学生信息管理系统\n\n");printf("[0] 保存信息并退出\n\n");printf("[1] 显示学生信息		");printf("[2] 新增学生信息\n\n");printf("[3] 搜索学生信息		");printf("[4] 删除学生信息\n\n");printf("[5] 统计学生性别信息		");printf("[6] 按英语成绩排序\n\n");printf("请输入选项(0 - 6):\n");scanf("%d",&choice);switch (choice){case 1://显示;print(stu);break;case 2://新增;printf("请输入新增学生的位置:\n");scanf("%d",&n);add(n);FILE *fp1 = fopen("datas.dat", "w");for(i=0;i<getlong(stu);i++)fprintf(fp1,"%s\t%d\t%s\t%f\t%f\t%f\n",stu[i].name,stu[i].id,stu[i].sex,stu[i].egl,stu[i].mat,stu[i].com);fclose(fp1);break;case 3://搜索;reserch();break;case 4://删除printf("[1] 按学生所在位置删除该生    ");printf("[2] 按学生学号删除该生\n");scanf("%d",&x);switch(x){case 1:printf("请输入要删除学生的位置:");scanf("%d",&n);delete1(n);FILE *fp2 = fopen("datas.dat", "w");for(i=0;i<getlong(stu);i++)fprintf(fp2,"%s\t%d\t%s\t%f\t%f\t%f\n",stu[i].name,stu[i].id,stu[i].sex,stu[i].egl,stu[i].mat,stu[i].com);fclose(fp2);break;case 2:delete2();FILE *fp3 = fopen("datas.dat", "w");for(i=0;i<getlong(stu);i++)fprintf(fp3,"%s\t%d\t%s\t%f\t%f\t%f\n",stu[i].name,stu[i].id,stu[i].sex,stu[i].egl,stu[i].mat,stu[i].com);fclose(fp3);break;default:printf("您输入的菜单有误。请重新输入!\n");}break;case 5://统计学生性别sexprint();break;case 6://按英语成绩排序yingyusort();break;case 0://退出程序printf("退出程序\n");printf("程序结束,谢谢使用!\n");exit(0);default:printf("您输入的菜单有误。请重新输入!\n");}}return 0;
}
int getlong(STUDENT stu_[])
{int i,k=0;for(i=0; ;i++){if(stu_[i].id!=0)k++;else break;}return k;
}
int print(STUDENT stu_[])
{int i;for( i=0; i<getlong(stu); i++){if(stu[i].id != 0)printf("姓名:%s\t 学号:%d\t 性别:%s\t 英语:%f\t 高数:%f\t 计算机:%f\t\n", stu[i].name,stu[i].id, stu[i].sex, stu[i].egl, stu[i].mat, stu[i].com);}return 0;
}
int add(int n)
{int i,k=getlong(stu);for(i=k;i>=n;i--){stu[i]=stu[i-1];}printf("请输入学生的姓名:\n");scanf("%s",stu[n-1].name);printf("请输入学生的学号:\n");scanf("%d",&stu[n-1].id);printf("请输入学生的性别:\n");scanf("%s",stu[n-1].sex);printf("请输入学生的英语成绩:\n");scanf("%f",&stu[n-1].egl);printf("请输入学生的高数成绩:\n");scanf("%f",&stu[n-1].mat);printf("请输入学生的计算机成绩:\n");scanf("%f",&stu[n-1].com);printf("录入完成,此时学生数为:%d\n",getlong(stu));return 0;
}
int reserch()
{int i,k=getlong(stu);char name1[100];printf("请输入想要查看学生的姓名:");scanf("%s",name1);for(i=0;i<k;i++){if(strcmp(name1,stu[i].name)==0){printf("该学生的学号为:%d,性别为:%s,英语成绩:%f,高数成绩:%f,计算机成绩:%f\n",stu[i].id, stu[i].sex, stu[i].egl, stu[i].mat, stu[i].com);break;}}if(i==k)printf("对不起,查无此人\n");return 0;
}
int delete1(int n)
{int i,k=getlong(stu);if( n>0 && n<=k ){for(i=n;i<=k;i++)stu[i-1]=stu[i];stu[i].id=0;printf("删除完成,此时学生数为:%d\n",getlong(stu));}else printf("该位置为假");return 0;
}
int delete2()
{int id1,i,j,k=getlong(stu);printf("请输入想要删除学生的学号:");scanf("%d",&id1);for(i=0;i<k;i++){if(id1==stu[i].id){for(j=i;j<k-1;j++)stu[j]=stu[j+1];stu[j].id=0;printf("删除完成,此时学生数为:%d\n",getlong(stu));break;}}if(i==k)printf("对不起,查无此人\n");return 0;
}
int sexprint()
{int i,k=getlong(stu),boynum=0,girlnum=0;char boy[100]="男";char girl[100]="女";printf("男生:\n");for(i=0;i<k;i++)if(strcmp(boy,stu[i].sex)==0){printf("姓名:%s\t学号:%d\t性别:%s\t英语:%f\t高数:%f\t计算机:%f\n", stu[i].name,stu[i].id, stu[i].sex, stu[i].egl, stu[i].mat, stu[i].com);boynum++;}printf("男生总数为:%d\n",boynum);printf("女生:\n");for(i=0;i<k;i++)if(strcmp(girl,stu[i].sex)==0){printf("姓名:%s\t学号:%d\t性别:%s\t英语:%f\t高数:%f\t计算机:%f\n", stu[i].name,stu[i].id, stu[i].sex, stu[i].egl, stu[i].mat, stu[i].com);girlnum++;}printf("女生总数为:%d\n",girlnum);return 0;
}
int yingyusort()
{int i, j, k=getlong(stu);STUDENT temp;for (i = 0; i < k-1 ; i++){for (j = 0; j < k - 1 - i; j++)if (stu[j].egl < stu[j+1].egl){temp = stu[j];stu[j] = stu[j+1];stu[j+1] = temp;}}for (i = 0; i < k; i++){if(stu[i].id != 0)printf("姓名:%s\t 学号:%d\t 性别:%s\t 英语:%f\t 高数:%f\t 计算机:%f\t\n", stu[i].name,stu[i].id, stu[i].sex, stu[i].egl, stu[i].mat, stu[i].com);}return 0;
}

将每个函数调用后的运行截图附录在此:
0.保存信息并退出:
在这里插入图片描述
1.显示学生信息:
在这里插入图片描述
2.新增学生信息:
在这里插入图片描述
在这里插入图片描述
3.搜索学生信息:
在这里插入图片描述
4.按学生位置删除学生信息:
在这里插入图片描述
按学号删除学生信息:
在这里插入图片描述
在这里插入图片描述
5.统计学生性别信息:
在这里插入图片描述
6.按英语成绩排序:
在这里插入图片描述

这篇关于C语言——课程设计的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/934744

相关文章

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

如何确定 Go 语言中 HTTP 连接池的最佳参数?

确定 Go 语言中 HTTP 连接池的最佳参数可以通过以下几种方式: 一、分析应用场景和需求 并发请求量: 确定应用程序在特定时间段内可能同时发起的 HTTP 请求数量。如果并发请求量很高,需要设置较大的连接池参数以满足需求。例如,对于一个高并发的 Web 服务,可能同时有数百个请求在处理,此时需要较大的连接池大小。可以通过压力测试工具模拟高并发场景,观察系统在不同并发请求下的性能表现,从而

C语言:柔性数组

数组定义 柔性数组 err int arr[0] = {0}; // ERROR 柔性数组 // 常见struct Test{int len;char arr[1024];} // 柔性数组struct Test{int len;char arr[0];}struct Test *t;t = malloc(sizeof(Test) + 11);strcpy(t->arr,

C语言指针入门 《C语言非常道》

C语言指针入门 《C语言非常道》 作为一个程序员,我接触 C 语言有十年了。有的朋友让我推荐 C 语言的参考书,我不敢乱推荐,尤其是国内作者写的书,往往七拼八凑,漏洞百出。 但是,李忠老师的《C语言非常道》值得一读。对了,李老师有个官网,网址是: 李忠老师官网 最棒的是,有配套的教学视频,可以试看。 试看点这里 接下来言归正传,讲解指针。以下内容很多都参考了李忠老师的《C语言非

C 语言基础之数组

文章目录 什么是数组数组变量的声明多维数组 什么是数组 数组,顾名思义,就是一组数。 假如班上有 30 个同学,让你编程统计每个人的分数,求最高分、最低分、平均分等。如果不知道数组,你只能这样写代码: int ZhangSan_score = 95;int LiSi_score = 90;......int LiuDong_score = 100;int Zhou

C 语言的基本数据类型

C 语言的基本数据类型 注:本文面向 C 语言初学者,如果你是熟手,那就不用看了。 有人问我,char、short、int、long、float、double 等这些关键字到底是什么意思,如果说他们是数据类型的话,那么为啥有这么多数据类型呢? 如果写了一句: int a; 那么执行的时候在内存中会有什么变化呢? 橡皮泥大家都玩过吧,一般你买橡皮泥的时候,店家会赠送一些模板。 上

linux中使用rust语言在不同进程之间通信

第一种:使用mmap映射相同文件 fn main() {let pid = std::process::id();println!(