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

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

相关文章

Java中switch-case结构的使用方法举例详解

《Java中switch-case结构的使用方法举例详解》:本文主要介绍Java中switch-case结构使用的相关资料,switch-case结构是Java中处理多个分支条件的一种有效方式,它... 目录前言一、switch-case结构的基本语法二、使用示例三、注意事项四、总结前言对于Java初学者

结构体和联合体的区别及说明

《结构体和联合体的区别及说明》文章主要介绍了C语言中的结构体和联合体,结构体是一种自定义的复合数据类型,可以包含多个成员,每个成员可以是不同的数据类型,联合体是一种特殊的数据结构,可以在内存中共享同一... 目录结构体和联合体的区别1. 结构体(Struct)2. 联合体(Union)3. 联合体与结构体的

PostgreSQL如何查询表结构和索引信息

《PostgreSQL如何查询表结构和索引信息》文章介绍了在PostgreSQL中查询表结构和索引信息的几种方法,包括使用`d`元命令、系统数据字典查询以及使用可视化工具DBeaver... 目录前言使用\d元命令查看表字段信息和索引信息通过系统数据字典查询表结构通过系统数据字典查询索引信息查询所有的表名可

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