寒假集训第一天--结构体训练

2024-08-25 01:58

本文主要是介绍寒假集训第一天--结构体训练,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.定义一个acmer结构体,包括以下信息:姓名,学号,手机号,做题数,出生日期,其中出生日期date也是一个结构体,包括年、月、日
2.建立结构体数组,实现对多个同学的信息输入,输出
3.实现简单的统计功能,比如统计做题数大于150的同  学并输出其完整信息
4.实现查找功能,包括按姓名、学号查找
5.实现信息修改功能
6.按做题数目进行排序(选作)
7.其他功能可以自由扩展,多多益善 ^_^
8.程序一个函数实现一个功能
9.代码测试成功后贴在论坛上,大家互相学习借鉴

#include <stdio.h>
#include <string.h>
void putandout(int n);
void sta(int n);
void fin(int n);
void sor(int n);
struct date {
int year ;
int month ;
int day ;
};
struct acmer {
char name[10] ;
char id[11] ;
char tel [11] ;
int oj ;
struct date birthday ;
}stu[100];
int main() {
int n , a ;
printf("输入数字n,输入n名学生数据(姓名 学号 手机号 做题数 出生年 月 日),n小于100。 \n");
scanf("%d", &n);
putandout(n);
while(1)
{
printf("请输入要实现的功能(1->统计 2->查找 3->修改 4->排序 输入0程序结束)\n");
scanf("%d", &a);
if(a==0)break;
if(a==1)
{
printf("输出做题数超过150的同学信息\n");
sta(n);
}
else if(a==2)
{
printf("输入学生姓名和学号查找学生信息\n");
fin(n);
}
else if(a==3)
{
printf("输入学生学号修改学生信息\n");
mon(n);
}
else if(a==4)
{
printf("对所有学生按做题数降序排序\n");
sor(n);
}
else
printf("输入命令错误,请重新输入\n");
}
return 0;
}
// 实现多名学生数据输入输出
void putandout(int n) {
int i ;
for(i = 0 ; i < n ; i++)
scanf("%s%s%s%d%d%d%d", stu[i].name , stu[i].id, stu[i].tel, &stu[i].oj, &stu[i].birthday.year, &stu[i].birthday.month, &stu[i].birthday.day );
printf("输出所有学生信息\n");
printf("姓名 学号 手机号 做题数 出生年 月 日\n");
for(i = 0 ; i < n ; i++)
printf("%s %s %s %d %d %d %d\n", stu[i].name , stu[i].id, stu[i].tel, stu[i].oj, stu[i].birthday.year, stu[i].birthday.month, stu[i].birthday.day );
}
//统计输出做题数超过150的同学信息
void sta(int n) {
int i , count = 0 ;
printf("姓名 学号 手机号 做题数 出生年 月 日\n");
for(i = 0 ; i < n ; i++)
{
if(stu[i].oj >= 150)
{
count++;
printf("%s %s %s %d %d %d %d\n", stu[i].name , stu[i].id, stu[i].tel, stu[i].oj, stu[i].birthday.year, stu[i].birthday.month, stu[i].birthday.day );
}
}
if(count==0)
printf("没有学生做题数超过150\n");
}
//输入学生姓名和学号进行查找
void fin(int n) {
int i , flag = 0 ;
char str1[10] , str2[11] ;
scanf("%s%s", str1, str2);
for(i = 0 ; i < n ; i++)
{
if(strcmp(str1,stu[i].name)==0 && strcmp(str2,stu[i].id)==0)
{
flag = 1 ;
printf("该生信息: 姓名:%s 学号:%s 手机号:%s 做题数:%d 出生年:%d 月:%d 日:%d\n", stu[i].name , stu[i].id, stu[i].tel, stu[i].oj, stu[i].birthday.year, stu[i].birthday.month, stu[i].birthday.day );
}
}
if(flag==0)
printf("没有该学生的信息\n");
}
// 输入学生学号,修改学生信息
void mon(int n){
int i , flag = 0 ;
char str[11] ;
scanf("%s", str);
for(i = 0 ; i < n ; i++)
{
if(strcmp(str,stu[i].id)==0)
{
flag = 1 ;
printf("原学生信息:%s %s %s %d %d %d %d\n请输入修改后的学生信息(姓名 学号 手机号 做题数 出生年 月 日)\n", stu[i].name , stu[i].id, stu[i].tel, stu[i].oj, stu[i].birthday.year, stu[i].birthday.month, stu[i].birthday.day );
scanf("%s %s %s %d %d %d %d", stu[i].name , stu[i].id, stu[i].tel, &stu[i].oj, &stu[i].birthday.year, &stu[i].birthday.month, &stu[i].birthday.day );
printf("修改成功,修改后的学生信息为 姓名:%s 学号:%s 手机号:%s 做题数:%d 出生年:%d 月:%d 日:%d\n", stu[i].name , stu[i].id, stu[i].tel, stu[i].oj, stu[i].birthday.year, stu[i].birthday.month, stu[i].birthday.day );
}
}
if(flag==0)
printf("没有该学生的信息\n");
}
//按做题数降序排列
void sor(int n) {
int i , j ;
for(i = 0 ; i < n ; i++)
{
for(j = i+1 ; j < n ; j++)
{
if(stu[i].oj< stu[j].oj)
{
struct acmer temp;
temp = stu[j] ; stu[j] = stu[i] ; stu[i] = temp ;
}
}
}
printf("姓名 学号 手机号 做题数 出生年 月 日\n");
for(i = 0 ; i < n ; i++)
printf("%s %s %s %d %d %d %d\n", stu[i].name , stu[i].id, stu[i].tel, stu[i].oj, stu[i].birthday.year, stu[i].birthday.month, stu[i].birthday.day );
}

这篇关于寒假集训第一天--结构体训练的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Redis中Set结构使用过程与原理说明

《Redis中Set结构使用过程与原理说明》本文解析了RedisSet数据结构,涵盖其基本操作(如添加、查找)、集合运算(交并差)、底层实现(intset与hashtable自动切换机制)、典型应用场... 目录开篇:从购物车到Redis Set一、Redis Set的基本操作1.1 编程常用命令1.2 集

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

Java集合中的链表与结构详解

《Java集合中的链表与结构详解》链表是一种物理存储结构上非连续的存储结构,数据元素的逻辑顺序的通过链表中的引用链接次序实现,文章对比ArrayList与LinkedList的结构差异,详细讲解了链表... 目录一、链表概念与结构二、当向单链表的实现2.1 准备工作2.2 初始化链表2.3 打印数据、链表长

创建springBoot模块没有目录结构的解决方案

《创建springBoot模块没有目录结构的解决方案》2023版IntelliJIDEA创建模块时可能出现目录结构识别错误,导致文件显示异常,解决方法为选择模块后点击确认,重新校准项目结构设置,确保源... 目录创建spChina编程ringBoot模块没有目录结构解决方案总结创建springBoot模块没有目录

SpringBoot利用树形结构优化查询速度

《SpringBoot利用树形结构优化查询速度》这篇文章主要为大家详细介绍了SpringBoot利用树形结构优化查询速度,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一个真实的性能灾难传统方案为什么这么慢N+1查询灾难性能测试数据对比核心解决方案:一次查询 + O(n)算法解决

Oracle查询表结构建表语句索引等方式

《Oracle查询表结构建表语句索引等方式》使用USER_TAB_COLUMNS查询表结构可避免系统隐藏字段(如LISTUSER的CLOB与VARCHAR2同名字段),这些字段可能为dbms_lob.... 目录oracle查询表结构建表语句索引1.用“USER_TAB_COLUMNS”查询表结构2.用“a

MySQL中的索引结构和分类实战案例详解

《MySQL中的索引结构和分类实战案例详解》本文详解MySQL索引结构与分类,涵盖B树、B+树、哈希及全文索引,分析其原理与优劣势,并结合实战案例探讨创建、管理及优化技巧,助力提升查询性能,感兴趣的朋... 目录一、索引概述1.1 索引的定义与作用1.2 索引的基本原理二、索引结构详解2.1 B树索引2.2

如何使用Maven创建web目录结构

《如何使用Maven创建web目录结构》:本文主要介绍如何使用Maven创建web目录结构的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录创建web工程第一步第二步第三步第四步第五步第六步第七步总结创建web工程第一步js通过Maven骨架创pytho

Python循环结构全面解析

《Python循环结构全面解析》循环中的代码会执行特定的次数,或者是执行到特定条件成立时结束循环,或者是针对某一集合中的所有项目都执行一次,这篇文章给大家介绍Python循环结构解析,感兴趣的朋友跟随... 目录for-in循环while循环循环控制语句break语句continue语句else子句嵌套的循

Python+PyQt5实现文件夹结构映射工具

《Python+PyQt5实现文件夹结构映射工具》在日常工作中,我们经常需要对文件夹结构进行复制和备份,本文将带来一款基于PyQt5开发的文件夹结构映射工具,感兴趣的小伙伴可以跟随小编一起学习一下... 目录概述功能亮点展示效果软件使用步骤代码解析1. 主窗口设计(FolderCopyApp)2. 拖拽路径