C语言基础练习(结构体)

描述

设有若干个人员的数据,其中包含学生和教师。学生的数据中包括:号码、姓名、性别、职业、班级。教师的数据包括:号码、姓名、性别、职业、职务。可以看出,学生和教师所包含的数据是不同的。现在要求把这些数据放在同一个表格中储存,使用结构体中的共用体实现。结构体定义如下:
struct {
int num;
char name[10];
char sex;
char job;
union {
int class;
char position[10];
}category;
};
在以上的结构体中,如果job项为s(学生),则第5项为class(班级);如果job项是t(教师),则第5项为position(职务)。
输入几个人员的数据,将其保存在以上包含共用体的结构体数组中,并输出。

输入

第一行有一个整数n,表示以下n行分别表示n个人员的数据。保证n不超过100。
之后的n行,每行有5项用空格隔开的内容。前4项分别为人员的号码(整数)、姓名(长度不超过9的无空格字符串)、性别(字符,m或f)和职业(字符,s或t)。如果第4项是s,则第5项为一个整数,表示班级;如果第4项是t,则第5项为一个长度不超过9的无空格字符串,表示职务。

输出

共有n行,与输入格式相同,输出读入的所有内容。
请注意行尾输出换行。

输入样例 1

2
101 Li f s 501
102 Wang m t prof

输出样例 1

101 Li f s 501
102 Wang m t prof

程序代码

#include <bits/stdc++.h>

using namespace std;

struct
{
    int num;
    char name[10];
    char sex;
    char job;
    union
    {
        int classs;
        char position[10];
    } category;
} a[100];
int main()
{
    int n;
    cin>>n;
    for(int i=0;i<n;i++)
    {
        cin>>a[i].num>>a[i].name>>a[i].sex>>a[i].job;
        if(a[i].job=='t')
        {
            cin>>a[i].category.position;
            cout<<a[i].num<<' '<<a[i].name<<' '<<a[i].sex<<' '<<a[i].job<<' '<<a[i].category.position<<endl;
        }
        else if(a[i].job=='s')
        {
            cin>>a[i].category.classs;
            cout<<a[i].num<<' '<<a[i].name<<' '<<a[i].sex<<' '<<a[i].job<<' '<<a[i].category.classs<<endl;
        }
    }
    return 0;
}

扩展资料

union,中文名“联合体、共用体”,在某种程度上类似结构体struct的一种数据结构,共用体(union)和结构体(struct)同样可以包含很多种数据类型和变量。
结构体(struct)中所有变量是“共存”的——优点是“有容乃大”,全面;缺点是struct内存空间的分配是粗放的,不管用不用,全分配。
而联合体(union)中是各变量是“互斥”的——缺点就是不够“包容”;但优点是内存使用更为精细灵活,也节省了内存空间。

定义:union是一种“类似”与struct的联合体,联合的所有成员引用的是内存中的相同位置,以最大的成员的内存长度作为union的内存大小。union主要用来节省空间,默认的访问权限是公有的。
注意点:
(1)同一个内存段可以用来存放几种不同类型的成员,但在每一个时刻只能存在其中一种,而不能同时存放几种,即每一瞬间只有一个成员起作用,其它的成员不起作用,不能同时都存在和起作用;
(2)共用体变量中起作用的成员是最后一个存放的成员,在存入一个新的成员后,原有的成员就会失去作用,即所有的数据成员具有相同的起始地址。

查找学生信息

描述

输入N个学生的信息,然后进行查询。

输入

输入的第一行为N,即学生的个数(N<=1000)

接下来的N行包括N个学生的信息,信息格式如下:
01 李江 男 21
02 刘唐 男 23
03 张军 男 19
04 王娜 女 19
然后输入一个M(M<=10000),接下来会有M行,代表M次查询,每行输入一个学号,格式如下:
02
03
01
04

输出

输出M行,每行包括一个对应于查询的学生的信息。
如果没有对应的学生信息,则输出“No Answer!”

输入样例 1

5
001 张三 男 19
002 李四 男 20
003 王五 男 18
004 赵六 女 17
005 刘七 女 21
7
003
002
005
004
003
001
006

输出样例 1

003 王五 男 18
002 李四 男 20
005 刘七 女 21
004 赵六 女 17
003 王五 男 18
001 张三 男 19
No Answer!

程序代码

#include <bits/stdc++.h>

using namespace std;

struct student
{
    char num[10];
    char name[100];
    char sex[5];
    int age;
} stu[1005];
int main()
{
    int n,m,i,j,k;
    char a[10];
    while(cin>>n&&n)
    {
        for(i=0;i<n;i++)
        {
            cin>>stu[i].num>>stu[i].name>>stu[i].sex>>stu[i].age;
        }
        cin>>m;
        for(k=0;k<m;k++)
        {
            cin>>a;
            for(j=0;j<=i;j++)
            {
                if(strcmp(stu[j].num,a)==0)//判断两个字符串是否相等
                {
                    cout<<stu[j].num<<" "<<stu[j].name<<" "<<stu[j].sex<<" "<<stu[j].age<<endl;
                    break;
                }
            }
            if(j==i+1)
            {
                cout<<"No Answer!"<<endl;
            }
        }
    }
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值