文章目录

  • 定义
  • 访问
  • 初始化
  • (1)定义的同时初始化
  • (2)先定义一个结构体变量,然后逐一赋值
  • (3)读入时赋值
  • (4)使用构造函数初始化
  • 优先级设置


定义

struct node
{
     char name[10];
     int age;
     int heigth;
     //结构体中能定义除本身外的任何数据类型
}person,class[100],*p;//可以在大括号外直接定义变量或数组

//结构体变量除了像上面那样定义外,也可以按照基本数据类型那样定义
node person1;

访问

访问person变量的写法

person.name
person.age
person.heigth

访问指针变量p中元素的写法

(*p).name
(*p).age
(*p).heigth
/*
或
p->name
p->age
p->heigth
两种写法完全等价
*/

初始化

(1)定义的同时初始化
node person={"zhang",20,168};
(2)先定义一个结构体变量,然后逐一赋值
person.name="zhang";
person.age=3;
/*
或一次性初始化
node person;
person=(struct node){"zhang",20,168};
*/
(3)读入时赋值
scanf("%s%d",person.name,&person.age);
(4)使用构造函数初始化

【用来初始化结构体的一种函数,它直接定义在结构体内,一般对一个普通定义的结构体其内部都会默认生成一个构造函数,由于构造函数存在,才能定义node型的变量而不经初始化】

struct node
{
     char name[10];
     int age;
     int heigth;
     node(){}//默认生成的构造函数,它没有返回类型,也没有函数体
};

我们要做的就是提供name,age,heigth的初始化参数

struct node
{
     char name[10];
     int age;
     int heigth;
     node(char str[],int x,int y)//此时默认生成的构造函数就被覆盖了,即不能不经初始化就定义结构体变量,若仍想定义不经初始化的结构体变量,可将之前默认生成的构造函数“node(){}”手动加上
     {
          strcpy(name,str);
          age=x;
          heigth=y;
     }
};

构造函数也可以简化为一行

node(char str[],int x,int y):name(str[]),age(x),heigth(y){}

这样就可以在需要时直接对结构体变量进行赋值了

node person1("zhang",18,168);
node person2=node("zhang",18,168);
person3=node("zhang",18,168);
queue<node>qu;
qu.push(node("zhang",18,168));

优先级设置

struct node
{
     char name[10];
     int age;
     int heigth;
     friend bool operator<(node a,node b)//重载小于号“<”
    {
        return a.age>b.age;//年龄小的优先级高
    }
};
priority_queue<node>qu;
  • 这个函数与sort中的cmp作用效果是相反的,因为sort默认为从小到大排序,优先队列默认为从大(即优先级高)到小。

也可以把它写在结构体外面,同时将其用struct包装起来

struct cmp
{
   bool operator()(node a,node b)//friend去掉,“<”换成“()”
   {
        return a.age>b.age;
   }
}
priority_queue<node,vector<node>,cmp>qu;

当结构体内数据较为庞大时,建议用引用来提高效率,即比较类的参数中加上const和&
friend bool operator<(const node &a,const node &b)
bool operator()(const node &a,const node &b)