//struct 结构体名 {结构体成员列表};
//读取时:结构体名.成员名
typedef struct s
{
char name[20];
int age;
}s;
int main()
{
//结构体数组
struct s data[3] =
{
{"zhangsan",17},
{"lisi",19},
{"wanger",27}
};
for (int i = 0; i < 3; i++)
cout << data[i].name <<" \t"<< data[i].age << endl;
return 0;
}
结构体指针,结构体嵌套
//结构体指针
//读取时:指针->成员名
int main()
{
s s1 = { "张三",18 };
s* s2 = &s1;
cout << s2->name << " \t" << s2->age << endl;
return 0;
}
//结构体嵌套结构体,在这之前已建立s结构体
typedef struct s
{
char name[20];
int age;
}s;
typedef struct t
{
char kemu[20];
s s1;
}t;
int main()
{
t t1 =
{
"李四",{"张三",18}
};
cout << t1.kemu << t1.s1.age << t1.s1.name << endl;
return 0;
}
结构体函数参数
//结构体做函数参数:1.值传递 2.地址传递
//结构体中const使用场景:用const防止误操作
typedef struct s
{
char name[20];
int age;
}s;
void out(const s* p)
{
cout << p->age << " " << p->name << endl;
}
int main()
{
s s1 = { "张三",18 };
out(&s1);
return 0;
}
老师与学生结构体
//三名老师带三个学生,学生有姓名分数,老师有姓名,可输入再输出
typedef struct s
{
char name[20];
int mark;
}s;
typedef struct t
{
char name[20];
s s_data[5];
}t;
int main()
{
t t_data[3] = { 0 };
for (int a = 0; a < 3; a++)
{
cout << "输入老师名字\n";
cin >> t_data[a].name;
for (int b=0; b < 3; b++)
{
cout << "输入学生的名字和成绩\n";
cin >> t_data[a].s_data[b].name >> t_data[a].s_data[b].mark;
}
cout << endl<<"输入下一位老师的名字及其学生\n";
}
cout << endl << endl << endl << "开始输出\n";
for (int j = 0; j < 3; j++)
{
cout<< t_data[j].name<<endl;
for (int k = 0; k < 3; k++)
{
cout<<t_data[j].s_data[k].name<<"\t" << t_data[j].s_data[k].mark<<endl;
}
}
return 0;
}
英雄结构体
//设计英雄结构体,有姓名,年龄,性别,存放五名,并使用冒泡排序按年龄大小输出
typedef struct hero
{
char name[20];
char sex[6];
int age;
}hero;
void input(hero a[],int k)
{
for (int i = 0; i < k; i++)
{
cout << "请输入名字,性别,年龄\n";
cin >> a[i].name >> a[i].sex >> a[i].age;
}
}
//排序
void p(hero b[],int l)
{
for (int x = 0; x < l - 1; x++)
{
for (int z = 0; z < l - x - 1; z++)
{
if (b[z].age > b[z + 1].age)
{
hero temp = b[z];
b[z]= b[z + 1];
b[z + 1] = temp;
}
}
}
}
//输出
void output(hero c[],int u)
{
for (int a = 0; a < u; a++)
{
cout << c[a].age << "\t" << c[a].sex << "\t" << c[a].name << endl;
}
}
int main()
{
hero data[5] = { 0 };
input(data,sizeof(data)/sizeof(data[0]));
p(data, sizeof(data) / sizeof(data[0]));
output(data, sizeof(data) / sizeof(data[0]));
return 0;
}