描述
设有若干个人员的数据,其中包含学生和教师。学生的数据中包括:号码、姓名、性别、职业、班级。教师的数据包括:号码、姓名、性别、职业、职务。可以看出,学生和教师所包含的数据是不同的。现在要求把这些数据放在同一个表格中储存,使用结构体中的共用体实现。结构体定义如下:
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;
}