【问题描述】设计并实现一个简单的学生成绩管理系统,学生成绩信息包括学号、姓名和成绩(成绩为整数)。用带头结点的单链表管理学生成绩表,每个学生的信息依次从键盘输入。根据功能要求设计相应的链表基本操作函数。具体功能要求如下: (1) 输入学生信息,按输入顺序建立一个带头结点的单链表,直到输入学号为0结束; (2) 在链表的尾部添加一个结点,然后以列表形式输出插入新结点后链表的所有学生基本信息; (3) 在链表的指定位置插入一个结点,如果插入成功,则输出插入新结点后链表的所有学生基本信息;否则输出Insert Failure。 【输入形式】首先输入若干行学生信息(每个学生的基本信息之间以空格分开),每行输入一个学生基本信息,输入学号0表示创建结束。接下来一行输入插入学生基本信息,以空格分开。接下来一行输入插入的位置和插入学生的基本信息 【输出形式】以列表形式输出创建的链表,每个学生的基本信息以空格分开。接下来一行输出在尾结点插入学生后的所有结点信息,接下来根据插入成功与否输出结果。 【样例输入1】 1101 Jhon 96 1103 Tomas 85 1104 Danny 78 0 1105 Shirry 65 2 1102 Katte 91 【样例输出1】 1101 Jhon 96 1103 Tomas 85 1104 Danny 78 1105 Shirry 65 1101 Jhon 96 1102 Katte 91 1103 Tomas 85 1104 Danny 78 1105 Shirry 65 【样例输入2】 1101 Jhon 96 1103 Tomas 85 1104 Danny 78 0 1105 Shirry 65 6 1102 Katte 91 【样例输出2】 1101 Jhon 96 1103 Tomas 85 1104 Danny 78 1105 Shirry 65 Insert Failure使用c语言编译

时间: 2023-05-20 19:05:14 浏览: 95
以下是一个简单的学生成绩管理系统的实现,使用带头结点的单链表来管理学生信息: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> // 学生信息结构体 typedef struct student { int id; // 学号 char name[20]; // 姓名 int score; // 成绩 struct student *next; // 指向下一个学生信息的指针 } Student; // 创建一个带头结点的空链表 Student *createList() { Student *head = (Student *)malloc(sizeof(Student)); head->next = NULL; return head; } // 在链表尾部添加一个学生信息 void addStudent(Student *head, int id, char *name, int score) { Student *p = head; while (p->next != NULL) { p = p->next; } Student *newStudent = (Student *)malloc(sizeof(Student)); newStudent->id = id; strcpy(newStudent->name, name); newStudent->score = score; newStudent->next = NULL; p->next = newStudent; } // 在链表指定位置插入一个学生信息 int insertStudent(Student *head, int pos, int id, char *name, int score) { Student *p = head; int i = 0; while (p != NULL && i < pos - 1) { p = p->next; i++; } if (p == NULL || i > pos - 1) { return 0; // 插入失败 } Student *newStudent = (Student *)malloc(sizeof(Student)); newStudent->id = id; strcpy(newStudent->name, name); newStudent->score = score; newStudent->next = p->next; p->next = newStudent; return 1; // 插入成功 } // 输出链表中所有学生信息 void printList(Student *head) { Student *p = head->next; while (p != NULL) { printf("%d %s %d\n", p->id, p->name, p->score); p = p->next; } } int main() { Student *head = createList(); int id, score, pos; char name[20]; // 输入学生信息,直到输入学号为0结束 while (1) { scanf("%d", &id); if (id == 0) { break; } scanf("%s%d", name, &score); addStudent(head, id, name, score); } // 在链表尾部添加一个学生信息 scanf("%d%s%d", &id, name, &score); addStudent(head, id, name, score); printList(head); // 在链表指定位置插入一个学生信息 scanf("%d%d%s%d", &pos, &id, name, &score); if (insertStudent(head, pos, id, name, score)) { printList(head); } else { printf("Insert Failure\n"); } return 0; } ``` 编译运行后,可以按照题目要求输入学生信息、插入学生信息和插入位置,然后输出链表中所有学生信息和插入结果。
阅读全文

相关推荐

大家在看

recommend-type

软件工程-总体设计概述(ppt-113页).ppt

软件工程-总体设计概述(ppt-113页).ppt
recommend-type

欧姆龙编码器E6B2-CWZ6C

本文档介绍了欧姆龙编码器的基本数据以及使用方式,可以供给那些需要使用欧姆龙编码器的同学阅读
recommend-type

中国移动5G规模试验测试规范--核心网领域--SA基础网元性能测试分册.pdf

目 录 前 言............................................................................................................................ 1 1. 范围........................................................................................................................... 2 2. 规范性引用文件....................................................................................................... 2 3. 术语、定义和缩略语............................................................................................... 2 3.1. 测试对象........................................................................................................ 3 4. 测试对象及网络拓扑............................................................................................... 3 ................................................................................................................................ 3 4.1. 测试组网........................................................................................................ 3 5. 业务模型和测试方法............................................................................................... 6 5.1. 业务模型........................................................................................................ 6 5.2. 测试方法........................................................................................................ 7 6. 测试用例................................................................................................................... 7 6.1. AMF性能测试................................................................................................ 7 6.1.1. 注册请求处理能力测试..................................................................... 7 6.1.2. 基于业务模型的单元容量测试.........................................................9 6.1.3. AMF并发连接管理性能测试........................................................... 10 6.2. SMF性能测试............................................................................................... 12 6.2.1. 会话创建处理能力测试................................................................... 12 6.2.2. 基
recommend-type

Pr1Wire2432Eng_reset_2432_

THIS SOFTWARE IS DESIGNED TO RESET CHIP 2432
recommend-type

10-虚拟内存的基本概念和请求分页处理方式.pdf

虚拟内存的基本概念和请求分页处理方式

最新推荐

recommend-type

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

《学生成绩管理系统》是一个基于C语言开发的实践项目,主要目标是实现对学生成绩的高效管理和分析。本系统采用数据结构的概念,包括数组、链表等数据结构,以实现对学生成绩数据的存储、操作和检索。以下是该系统的...
recommend-type

学生成绩管理系统实验报告.doc

【学生成绩管理系统】是一个基于C++编程的实训项目,旨在让学习者深入理解面向对象程序设计的概念和技术。系统的主要功能包括添加、查询、显示、编辑、删除学生记录,统计成绩,保存和读取数据,以及按成绩进行排序...
recommend-type

C++ 学生成绩管理系统设计报告书

学生成绩管理系统是一种基于C++的面向对象程序设计的应用,旨在提供一套全面的功能,用于管理学生的基本信息、考试成绩以及进行数据分析。以下是该系统的主要设计和实现细节: **一、系统需求分析** 系统的主要...
recommend-type

JavaWeb设计成绩管理系统(报告书)

在本报告中,我们将探讨基于JavaWeb技术设计的成绩管理系统,主要关注学生和教师信息的处理。这个系统旨在提供一个高效、可靠且用户友好的平台,用于管理教育机构内的学生成绩和教师信息。 2.2.1 学生信息处理 ...
recommend-type

C语言数组实现学生信息管理系统设计

"C语言数组实现学生信息管理系统设计" 本文主要介绍了使用C语言数组实现学生信息管理系统的设计,涵盖了学生信息的录入、输出、查找、排序和删除等功能。该系统使用多个数组来存储学生信息,包括学生姓名、数学成绩...
recommend-type

Terraform AWS ACM 59版本测试与实践

资源摘要信息:"本资源是关于Terraform在AWS上操作ACM(AWS Certificate Manager)的模块的测试版本。Terraform是一个开源的基础设施即代码(Infrastructure as Code,IaC)工具,它允许用户使用代码定义和部署云资源。AWS Certificate Manager(ACM)是亚马逊提供的一个服务,用于自动化申请、管理和部署SSL/TLS证书。在本资源中,我们特别关注的是Terraform的一个特定版本的AWS ACM模块的测试内容,版本号为59。 在AWS中部署和管理SSL/TLS证书是确保网站和应用程序安全通信的关键步骤。ACM服务可以免费管理这些证书,当与Terraform结合使用时,可以让开发者以声明性的方式自动化证书的获取和配置,这样可以大大简化证书管理流程,并保持与AWS基础设施的集成。 通过使用Terraform的AWS ACM模块,开发人员可以编写Terraform配置文件,通过简单的命令行指令就能申请、部署和续订SSL/TLS证书。这个模块可以实现以下功能: 1. 自动申请Let's Encrypt的免费证书或者导入现有的证书。 2. 将证书与AWS服务关联,如ELB(Elastic Load Balancing)、CloudFront和API Gateway等。 3. 管理证书的过期时间,自动续订证书以避免服务中断。 4. 在多区域部署中同步证书信息,确保全局服务的一致性。 测试版本59的资源意味着开发者可以验证这个版本是否满足了需求,是否存在任何的bug或不足之处,并且提供反馈。在这个版本中,开发者可以测试Terraform AWS ACM模块的稳定性和性能,确保在真实环境中部署前一切工作正常。测试内容可能包括以下几个方面: - 模块代码的语法和结构检查。 - 模块是否能够正确执行所有功能。 - 模块与AWS ACM服务的兼容性和集成。 - 模块部署后证书的获取、安装和续订的可靠性。 - 多区域部署的证书同步机制是否有效。 - 测试异常情况下的错误处理机制。 - 确保文档的准确性和完整性。 由于资源中没有提供具体的标签,我们无法从中获取关于测试的详细技术信息。同样,由于只提供了一个文件名“terraform-aws-acm-59-master”,无法得知该模块具体包含哪些文件和代码内容。然而,文件名暗示这是一个主版本(master),通常意味着这是主要的、稳定的分支,开发者可以在其上构建和测试他们的配置。 总之,terraform-aws-acm-59是Terraform的一个AWS ACM模块的测试版本,用于自动化管理和部署SSL/TLS证书。这个模块能够简化证书生命周期的管理,并提高与AWS服务的集成效率。测试工作主要是为了验证版本59的模块是否正常工作,并确保其在真实场景中可靠地执行预期功能。"
recommend-type

【HS1101湿敏电阻全面解析】:从基础知识到深度应用的完整指南

# 摘要 HS1101湿敏电阻作为湿度监测的重要元件,在环境监测、农业、工业等多个领域都有广泛应用。本文首先对湿敏电阻的基本概念及其工作原理进行了概述,接着详细探讨了其特性参数,如响应时间、灵敏度以及温度系数等,并针对HS1101型号提供了选型指南和实际应用场景分析。文章还深入讨论了HS1101湿敏电阻在电路设计中的要点和信号处理方法,提供了实践案例来展示其在智能湿度调节器和农业自动灌溉系统中的应用。最后,本文给出了湿敏电阻的维护保养技巧和故障排除方法,以帮助用户确保湿敏电阻的最佳性能和使用寿命。 # 关键字 湿敏电阻;HS1101;特性参数;电路设计;信号处理;环境监测;故障排除 参考资
recommend-type

MATLAB在一个图形窗口中创建一行两列的子图的代码

在MATLAB中,可以使用`subplot`函数在一个图形窗口中创建多个子图。对于一行两列的子图,可以使用以下代码: ```matlab % 创建第一个子图 subplot(1, 2, 1); plot([1, 2, 3], [4, 5, 6]); title('子图1'); % 创建第二个子图 subplot(1, 2, 2); plot([1, 2, 3], [6, 5, 4]); title('子图2'); ``` 这段代码的详细解释如下: 1. `subplot(1, 2, 1);`:创建一个1行2列的子图布局,并激活第一个子图。 2. `plot([1, 2, 3], [4,
recommend-type

Doks Hugo主题:打造安全快速的现代文档网站

资源摘要信息:"Doks是一个适用于Hugo的现代文档主题,旨在帮助用户构建安全、快速且对搜索引擎优化友好的文档网站。在短短1分钟内即可启动一个具有Doks特色的演示网站。以下是选择Doks的九个理由: 1. 安全意识:Doks默认提供高安全性的设置,支持在上线时获得A+的安全评分。用户还可以根据自己的需求轻松更改默认的安全标题。 2. 默认快速:Doks致力于打造速度,通过删除未使用的CSS,实施预取链接和图像延迟加载技术,在上线时自动达到100分的速度评价。这些优化有助于提升网站加载速度,提供更佳的用户体验。 3. SEO就绪:Doks内置了对结构化数据、开放图谱和Twitter卡的智能默认设置,以帮助网站更好地被搜索引擎发现和索引。用户也能根据自己的喜好对SEO设置进行调整。 4. 开发工具:Doks为开发人员提供了丰富的工具,包括代码检查功能,以确保样式、脚本和标记无错误。同时,还支持自动或手动修复常见问题,保障代码质量。 5. 引导框架:Doks利用Bootstrap框架来构建网站,使得网站不仅健壮、灵活而且直观易用。当然,如果用户有其他前端框架的需求,也可以轻松替换使用。 6. Netlify就绪:Doks为部署到Netlify提供了合理的默认配置。用户可以利用Netlify平台的便利性,轻松部署和维护自己的网站。 7. SCSS支持:在文档主题中提及了SCSS,这表明Doks支持使用SCSS作为样式表预处理器,允许更高级的CSS样式化和模块化设计。 8. 多语言支持:虽然没有在描述中明确提及,但Doks作为Hugo主题,通常具备多语言支持功能,这为构建国际化文档网站提供了便利。 9. 定制性和可扩展性:Doks通过其设计和功能的灵活性,允许用户根据自己的品牌和项目需求进行定制。这包括主题颜色、布局选项以及组件的添加或修改。 文件名称 'docs-main' 可能是Doks主题的核心文件,包含网站的主要内容和配置。这个文件对于设置和维护文档网站来说是至关重要的,因为它包含了网站的主要配置信息,如导航结构、品牌设置、SEO配置等。开发者在使用Doks主题时,将重点调整和优化这个文件以满足具体的项目需求。"
recommend-type

E9流程表单前端接口API(V5):前端与后端协同开发的黄金法则

![E9流程表单前端接口API(V5):前端与后端协同开发的黄金法则](https://opengraph.githubassets.com/4b7b246f81a756c8056ca0f80a5b46fad74e128b86dec7d59f1aeedb4b99c6a7/sotiriosmoustogiannis/process-json-format) # 摘要 本文全面介绍了E9流程表单API(V5)的开发与应用,阐述了协同开发理论基础和前端实践,并结合案例分析展示了API在企业流程自动化中的实战应用。文章首先概述了E9流程表单API(V5)的核心概念,然后详细探讨了前后端协同开发的重要