帮我用c语言设计一个学生成绩查询统计系统,以下是具体要求(1)分析数据的逻辑结构。 (2)设计数据的存储结构。(诸如一个记录应包括哪些字段数据,每个字段的数据是什么类型的,应用什么数据结构来保存众多的记录) (3)根据学生姓名进行字典排序。 (4)根据成绩进行由高到低排序。(可采用冒泡法或其他快速算法) (5)根据学号或姓名查找学生成绩。(可采用顺序查找或二分查找等方法,并实现查找结构的打印) (6)统计各分数段(≥90分、80-89分、70-79分、60-69分、60分以下)的学生人数及其所占比例,并打印统计的结果。 (7)编写主要的C语言代码,尤其是对函数头部涉及的主要参数要进行注释说明。 (8)系统的程序结构可以考虑采用多文件组合框架,也可以采用单文件多模块组合框架。

时间: 2024-04-04 19:32:59 浏览: 26
好的,以下是我给你的C语言代码,实现了上述要求: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> // 定义学生信息结构体 typedef struct { char id[20]; // 学号 char name[20]; // 姓名 float scores[5]; // 各科成绩 } Student; // 定义链表节点结构体 typedef struct Node { Student data; // 学生信息 struct Node *next; // 指向下一个节点的指针 } Node; // 定义全局变量,指向链表的头节点和尾节点 Node *head = NULL; Node *tail = NULL; // 定义函数,向链表中添加一个学生信息 void addStudent() { // 申请一个新的节点空间 Node *node = (Node *)malloc(sizeof(Node)); // 申请动态内存分配空间来存储学生成绩数组 for (int i = 0; i < 5; i++) { node->data.scores[i] = (float *)malloc(sizeof(float)); } // 输入学生信息 printf("请输入学生学号:"); scanf("%s", node->data.id); printf("请输入学生姓名:"); scanf("%s", node->data.name); printf("请输入学生各科成绩(语文、数学、英语、物理、化学):\n"); for (int i = 0; i < 5; i++) { scanf("%f", &node->data.scores[i]); } // 将新节点添加到链表中 node->next = NULL; if (head == NULL) { head = tail = node; } else { tail->next = node; tail = node; } printf("添加成功!\n"); } // 定义函数,根据学生姓名进行字典排序 void sortByName() { Node *p, *q; Student temp; for (p = head; p != NULL; p = p->next) { for (q = p->next; q != NULL; q = q->next) { if (strcmp(p->data.name, q->data.name) > 0) { temp = p->data; p->data = q->data; q->data = temp; } } } printf("已按姓名排序!\n"); } // 定义函数,根据成绩进行由高到低排序 void sortByScore() { Node *p, *q; Student temp; for (p = head; p != NULL; p = p->next) { for (q = p->next; q != NULL; q = q->next) { float sum1 = 0, sum2 = 0; for (int i = 0; i < 5; i++) { sum1 += p->data.scores[i]; sum2 += q->data.scores[i]; } if (sum1 < sum2) { temp = p->data; p->data = q->data; q->data = temp; } } } printf("已按成绩排序!\n"); } // 定义函数,根据学号或姓名查找学生成绩 void search() { char keyword[20]; printf("请输入要查找的学生学号或姓名:"); scanf("%s", keyword); int flag = 0; Node *p; for (p = head; p != NULL; p = p->next) { if (strcmp(p->data.id, keyword) == 0 || strcmp(p->data.name, keyword) == 0) { printf("学号:%s\n", p->data.id); printf("姓名:%s\n", p->data.name); printf("成绩:语文 %.2f,数学 %.2f,英语 %.2f,物理 %.2f,化学 %.2f\n", p->data.scores[0], p->data.scores[1], p->data.scores[2], p->data.scores[3], p->data.scores[4]); flag = 1; } } if (!flag) { printf("未找到对应学生信息!\n"); } } // 定义函数,统计各分数段的学生人数及其所占比例 void statistic() { int count1 = 0, count2 = 0, count3 = 0, count4 = 0, count5 = 0; for (Node *p = head; p != NULL; p = p->next) { float sum = 0; for (int i = 0; i < 5; i++) { sum += p->data.scores[i]; } float avg = sum / 5.0; if (avg >= 90) { count1++; } else if (avg >= 80) { count2++; } else if (avg >= 70) { count3++; } else if (avg >= 60) { count4++; } else { count5++; } } printf("各分数段学生人数及所占比例如下:\n"); printf("90分及以上: %d 人,%.2f%%\n", count1, count1 * 100.0 / (count1 + count2 + count3 + count4 + count5)); printf("80分至89分: %d 人,%.2f%%\n", count2, count2 * 100.0 / (count1 + count2 + count3 + count4 + count5)); printf("70分至79分: %d 人,%.2f%%\n", count3, count3 * 100.0 / (count1 + count2 + count3 + count4 + count5)); printf("60分至69分: %d 人,%.2f%%\n", count4, count4 * 100.0 / (count1 + count2 + count3 + count4 + count5)); printf("60分以下: %d 人,%.2f%%\n", count5, count5 * 100.0 / (count1 + count2 + count3 + count4 + count5)); } // 定义函数,释放链表的内存空间 void freeList() { Node *p, *q; for (p = head; p != NULL; p = q) { q = p->next; // 释放节点中动态分配的内存空间 for (int i = 0; i < 5; i++) { free(p->data.scores[i]); } // 释放节点空间 free(p); } } int main() { int choice; do { printf("\n\n"); printf("*****************************************\n"); printf("* 学生成绩查询统计系统 *\n"); printf("*****************************************\n"); printf("* *\n"); printf("* 1. 添加学生信息 *\n"); printf("* 2. 按姓名排序 *\n"); printf("* 3. 按成绩排序 *\n"); printf("* 4. 查找学生信息 *\n"); printf("* 5. 统计各分数段人数及比例 *\n"); printf("* 0. 退出程序 *\n"); printf("* *\n"); printf("*****************************************\n"); printf("\n请输入操作选项:"); scanf("%d", &choice); switch (choice) { case 1: addStudent(); break; case 2: sortByName(); break; case 3: sortByScore(); break; case 4: search(); break; case 5: statistic(); break; case 0: // 释放链表的内存空间,并退出程序 freeList(); printf("程序已退出!\n"); exit(0); default: printf("无效操作!\n"); break; } } while (1); return 0; } ``` 注意:上述代码中使用了动态内存分配的方式来存储学生成绩数组,并且在释放链表的内存空间时,需要先释放节点中动态分配的内存空间。

相关推荐

最新推荐

recommend-type

C语言程序设计实现学生成绩记录簿

通过编写c语言《学生成绩记录簿系统...3)C语言程序设计的主要任务是要求学生遵循软件开发过程的基本规范,运用结构化程序设计的方法,按照课程设计的题目要求,分析、设计、编写、调试和测试C语言程序及编写设计报告。
recommend-type

学生成绩管理系统(数据结构)实验报告.docx

期末实践周必备(数据结构)学生成绩管理系统,基于C语言完成的,百分百作者原创,资源保证!
recommend-type

C语言程序设计实现区号查询系统C语言程序设计实现

用C语言编程的区号查询系统,要求实现区号查询系统中,添加新记录、删除记录、显示记录信息、按城市查找信息和退出系统等功能。 ①录入有关城市的名称和区号。 ②显示所有城市的信息。 ③通过输入城市名称查找对应...
recommend-type

c语言作业——学生成绩统计.docx

(1)学生基本信息(学号、姓名、…….)录入; (2)学生成绩录入; (3)统计学生成绩分布情况(每个分数段人数); (4)查找最高分、最低分;计算学生成绩均值和方差;并输出这四个结果; (5)判断成绩是否服从...
recommend-type

小学生测验C语言课程设计报告

1.通过本课程设计,培养上机动手能力,使学生巩固《C语言程序设计》课程学习的内容,掌握工程软件设计的基本方法,强化上机动手能力,闯过编程关; 2.为后续各门计算机课程的学习打下坚实基础; 3.理解程序设计的思路...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

2. 通过python绘制y=e-xsin(2πx)图像

可以使用matplotlib库来绘制这个函数的图像。以下是一段示例代码: ```python import numpy as np import matplotlib.pyplot as plt def func(x): return np.exp(-x) * np.sin(2 * np.pi * x) x = np.linspace(0, 5, 500) y = func(x) plt.plot(x, y) plt.xlabel('x') plt.ylabel('y') plt.title('y = e^{-x} sin(2πx)') plt.show() ``` 运行这段
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。