查看: 307|回复: 2
收起左侧

[树/链表/图] 请问对于图的邻接表或者邻接矩阵的定义有什么讲究吗?

|只看干货
ttxs2016 | 显示全部楼层 |阅读模式
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   100% (13)
 
 
0% (0)    👎

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看附件。没有帐号?注册账号

x
本帖最后由 ttxs2016 于 2021-10-16 14:52 编辑

小弟在刷题过程中,经常发现需要把一些问题定义成graph的情况,看各路大神的答案时,发现存储graph的方法也是很多。
以C++为例,比如LC第399题,一个常见做法就是 定义 unordered_map<string, unordered_map<string,double>> g;
而332也差不多 unordered_map<string, dequeue<string>> trips; 这个dequeue就是为了访问首个元素,大同小异。
但是323题却是这样定义的 vector<vector<int>> g;感觉定义的还是一个邻接表,而不是邻接矩阵。

请问一般这种需要构建graph的题,在定义g上有什么讲究吗?什么情况用什么结构比较方便呢?

评分

参与人数 1大米 +6 收起 理由
14417335 + 6

查看全部评分


上一篇:最大长方形那题面试真的能写完?
下一篇:189 rotate array如何想到三次翻转?
wisdompeak2 2021-10-18 09:39:49 | 显示全部楼层
本楼: 👍   100% (1)
 
 
0% (0)   👎
全局: 👍   98% (569)
 
 
1% (11)    👎
很显然,取决于节点是用数字表示还是用字符串表示。如果是后者,只能用unordered_map<string, unordered_map<string,double>> 了呗

如果题目告诉你节点使用数字表示,并且编号从0到n-1, 那么 vector<vector<int>> g(n) 的写法更方便,内存的使用也更高效。

评分

参与人数 1大米 +1 收起 理由
ttxs2016 + 1 很有用的信息!

查看全部评分

回复

使用道具 举报

baonudesifeizha 2021-10-17 08:10:32 | 显示全部楼层
本楼: 👍   100% (1)
 
 
0% (0)   👎
全局: 👍   81% (1071)
 
 
18% (239)    👎
没有讲究   纯粹看自己心情  

大多数人习惯写成g 不管是邻接表还是邻接数组
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

>
快速回复 返回顶部 返回列表