《算法笔记》第4章 入门篇(2)---算法初步 10.1图的定义和相关术语 10.2 图的存储

10.1 图的定义和相关术语

在这里插入图片描述
在这里插入图片描述

图的存储

1.邻接矩阵:

在这里插入图片描述

2.邻接表:

在这里插入图片描述
在这里插入图片描述

struct node
{
	int v,w;
	node(int _v, int _w):v{_v},w{_w} {} 		//构造函数
}

构造函数:

在这里插入图片描述


#include<iostream>
using namespace std;


struct studentInfo
{
    int id;
    char gender;
    /*
    studentInfo(int _id, char _gender)  //默认的
    {
        //赋值
        id=_id;
        gender=_gender;
    }*/
    //构造函数可以简化为1行
    studentInfo(int _id, char _gender):id(_id),gender(_gender) {}
};

int main()
{
    studentInfo a=studentInfo(22,'m');
    cout << a.id << " "<< a.gender;
}

在这里插入图片描述

在这里插入图片描述

自己定义构造函数后不能用不经初始化就定义结构体变量

#include<iostream>
using namespace std;


struct studentInfo
{
    int id;
    char gender;
    /*
    studentInfo(int _id, char _gender)  //默认的
    {
        //赋值
        id=_id;
        gender=_gender;
    }*/
    //构造函数可以简化为1行
    studentInfo(int _id, char _gender):id(_id),gender(_gender) {}
};

int main()
{
    studentInfo x;

}

在这里插入图片描述
既能不用初始化定义,又能享受初始化的便捷

#include<iostream>
using namespace std;


struct studentInfo
{
    int id;
    char gender;
    studentInfo() {}       //用以不初始化就定义结构体变量
    
    studentInfo(char _gender)  //默认的
    {
        gender=_gender;
    }
    
    //同时初始化id和gender
    studentInfo(int _id, char _gender)
    {
        id=_id;
        gender=_gender;
    }
    
};

实例:

#include<iostream>
using namespace std;

struct Point
{
    int x,y;
    Point(){};     //用以不经初始化定义pt[10]
    Point(int _x, int _y): x(_x),y(_y) {}  //用以提供x和y的初始化
}pt[10];

int main()
{
    int num=10;
    for(int i=1; i<=3; i++)
        for(int j=1; j<=3; j++)
        {
            pt[num++]=Point(i,j);

        }
    for(int i=0; i<num; i++)
        cout << pt[i].x << " " << pt[i].y << " " << endl;
}

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值