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

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

相关文章

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

自定义类型:结构体(续)

目录 一. 结构体的内存对齐 1.1 为什么存在内存对齐? 1.2 修改默认对齐数 二. 结构体传参 三. 结构体实现位段 一. 结构体的内存对齐 在前面的文章里我们已经讲过一部分的内存对齐的知识,并举出了两个例子,我们再举出两个例子继续说明: struct S3{double a;int b;char c;};int mian(){printf("%zd\n",s

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

OpenCV结构分析与形状描述符(11)椭圆拟合函数fitEllipse()的使用

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C++11 算法描述 围绕一组2D点拟合一个椭圆。 该函数计算出一个椭圆,该椭圆在最小二乘意义上最好地拟合一组2D点。它返回一个内切椭圆的旋转矩形。使用了由[90]描述的第一个算法。开发者应该注意,由于数据点靠近包含的 Mat 元素的边界,返回的椭圆/旋转矩形数据

Spark MLlib模型训练—聚类算法 PIC(Power Iteration Clustering)

Spark MLlib模型训练—聚类算法 PIC(Power Iteration Clustering) Power Iteration Clustering (PIC) 是一种基于图的聚类算法,用于在大规模数据集上进行高效的社区检测。PIC 算法的核心思想是通过迭代图的幂运算来发现数据中的潜在簇。该算法适用于处理大规模图数据,特别是在社交网络分析、推荐系统和生物信息学等领域具有广泛应用。Spa

SigLIP——采用sigmoid损失的图文预训练方式

SigLIP——采用sigmoid损失的图文预训练方式 FesianXu 20240825 at Wechat Search Team 前言 CLIP中的infoNCE损失是一种对比性损失,在SigLIP这个工作中,作者提出采用非对比性的sigmoid损失,能够更高效地进行图文预训练,本文进行介绍。如有谬误请见谅并联系指出,本文遵守CC 4.0 BY-SA版权协议,转载请联系作者并注

Java基础回顾系列-第一天-基本语法

基本语法 Java基础回顾系列-第一天-基本语法基础常识人机交互方式常用的DOS命令什么是计算机语言(编程语言) Java语言简介Java程序运行机制Java虚拟机(Java Virtual Machine)垃圾收集机制(Garbage Collection) Java语言的特点面向对象健壮性跨平台性 编写第一个Java程序什么是JDK, JRE下载及安装 JDK配置环境变量 pathHe

Detectorn2预训练模型复现:数据准备、训练命令、日志分析与输出目录

Detectorn2预训练模型复现:数据准备、训练命令、日志分析与输出目录 在深度学习项目中,目标检测是一项重要的任务。本文将详细介绍如何使用Detectron2进行目标检测模型的复现训练,涵盖训练数据准备、训练命令、训练日志分析、训练指标以及训练输出目录的各个文件及其作用。特别地,我们将演示在训练过程中出现中断后,如何使用 resume 功能继续训练,并将我们复现的模型与Model Zoo中的

C语言程序设计(选择结构程序设计)

一、关系运算符和关系表达式 1.1关系运算符及其优先次序 ①<(小于) ②<=(小于或等于) ③>(大于) ④>=(大于或等于 ) ⑤==(等于) ⑥!=(不等于) 说明: 前4个优先级相同,后2个优先级相同,关系运算符的优先级低于算术运算符,关系运算符的优先级高于赋值运算符 1.2关系表达式 用关系运算符将两个表达式(可以是算术表达式或关系表达式,逻辑表达式,赋值表达式,字符

Science|癌症中三级淋巴结构的免疫调节作用与治疗潜力|顶刊精析·24-09-08

小罗碎碎念 Science文献精析 今天精析的这一篇综述,于2022-01-07发表于Science,主要讨论了癌症中的三级淋巴结构(Tertiary Lymphoid Structures, TLS)及其在肿瘤免疫反应中的作用。 作者类型作者姓名单位名称(中文)通讯作者介绍第一作者Ton N. Schumacher荷兰癌症研究所通讯作者之一通讯作者Daniela S. Thomm