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

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 );
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值