图论初步<蒟蒻专属文章>

前言:    图论乃noip之重要知识点,但有点难理解 本人因此吃过不少亏

因为本人实在太弱,所以此篇乃正宗<蒟蒻专属文章>

正文:(本文仅介绍图论中的重点、难点,其余部分略将或不讲)

图一般来说有二种存储方法:邻接矩阵和邻接表

邻接矩阵:

存储:拿二维数组来存
  

for(int i=1;i<=n;++i){   //f[q][z]表示点q与点z有没有边相连接
    cin>>q>>z;  //noip基本别指望,最多三四十分
    f[q][z]=1;  //无向边要存双向
    f[z][q]=1;
} 

可是,虽然存储简单,可效率也太低了(尤其是些超级稀疏的矩阵)

  而且,坏处还没完:读取效率也很低!

读取:

  

cin>>x;//读入x,查与x有关的点
for(int i=1;i<=n;++i){  //据说++i比i++快一些
    if(f[x][i]==1){
        cout<<i<<" ";
    }
} 

这么暴力的for循环,不超时才怪呢

所以,另一种办法来了:邻接表!!

原理:

通过链表的形式,高效的存储/读取边

先使用struct:(我太蒻,只会用struct存)

struct node{
           int u,v,next;//u起点,v终点,next待会在说 啥意思
   }e[MAXN*2]; //无向图要*2(原因:要存两次)!!!!有向图似乎只要一倍
   //这类数组名都用e,养成好习惯 

读取:

for(int i=1;i<=n;++i){
       cin>>q>>z;  //这类函数名名都用e,养成好习惯
       add(q,z);  //无向边要存双向
       add(z,q);  //通常 用自定义函数实现
   }

add(加边函数):    注意:要定义head数组,表示点i当前的第一个连接的数组下标!!!!!

代码:

void add(int x,int y,){
   ++tot;
   e[tot].u=x;
   e[tot].v=y;
   e[tot].next=head[x];
   head[x]=tot;
}

一些question&Answer&注意事项:

1:为什么偏偏要插队?

Answer:因为如果不插队,将要加的边就没法指向上一个了(难道你还for一遍?);

2:链表结构其实还有很多其余的办法实现,但我写的这种更适合初学者

(emm.....好像就两个也)

“遍历”方式:

cin>>a; //问和a号点相邻的边有哪些
    for(int i=head[a];i!=0;i=e[i].next){  //从点a的第一条边开始,若为0结束
        cout<<e[i].u<<" "<<e[i].v<<endl;   // 到下一个数组下标
    } 

(完)

写在后面的话:

这是我的第一篇博客(bug一定很多)

  本人的个人主页(洛谷)https://www.luogu.com.cn/user/236929

本人的个人主页https://www.cnblogs.com/Craker/

欢迎来访!

谢谢!

本人QQ:2783119105

本人邮箱:[email protected]

如有问题,请在评论区指出或私信我,

谢谢!

原文地址:https://www.cnblogs.com/Craker/p/12271090.html

时间: 2024-07-30 17:52:28

图论初步<蒟蒻专属文章>的相关文章

算法描述》LCA两三事(蒟蒻向)

LCA是图论中常用的解决树形结构子问题的工具,这一问题一般需要用一个简短的子函数直接解决,但是这对于广大蒟蒻们仍然是一个不小的问题. LCA是指在树形结构中两点的最近公共祖先,对于这个问题,直接向上找事最直接的方法,但同时时间复杂度和数据给出的生成树的层数有关,最优情况是logN级别的,但是如果数据给出的是一条链就GG了,所以要用更优的方法写,一般来说,用的是log2N的操作,最糟糕的复杂度也是logN级别的,那如何实现这一过程捏,我这里有两种方法,和大家分享 第一种:树上倍增 具体方法是对于已

蒟蒻的第一篇博文

先刷一波存在感... 据说维护Blog可以作为积累然后就决定开一波Blog=.= 本来想用Hexo Framework加上GitHub Pages做一个Blog来着(因为GitHub比较Geek嘛) 然后折腾了半天搞了个NexT Theme感觉异常地漂亮 然后Commit上了GitHub还写了几篇测试文章自我感觉良好 然后调整了一发文件夹结构因为我总是要移动工作区 然后折腾了一段时间感觉这个Blog估计可以使了 然后... 然后突然发现Hexo Framework构造的是一大坨静态页面没法加载数

蒟蒻ACMer回忆录 &#183; 一段弱校ACM的奋斗史

三年半的ACM生涯终于迎来了终点,退役之时,感慨万分,故写此文以纪念逝去的时光,那些为ACM拼搏的日子,那段弱校ACM的奋斗史. 三年半的ACM生涯,窝见证了CUMT从打铁到铜牌的突破,又见证了从铜牌到银牌的突破:见证了集训队员从3人发展到10余人,又见证了ACM实验室的落实. 三年半的ACM生涯,窝经历了太多,有Accepted时的欢笑,有Wrong Answer时的沮丧,有Time Limit Exceeded时的无奈,有Runtime Error时的尴尬,有打铁的失落,有拿牌的惊喜. 13

bzoj 4636: 蒟蒻的数列

4636: 蒟蒻的数列 Description 蒟蒻DCrusher不仅喜欢玩扑克,还喜欢研究数列 题目描述 DCrusher有一个数列,初始值均为0,他进行N次操作,每次将数列[a,b)这个区间中所有比k小的数改为k,他想知 道N次操作后数列中所有元素的和.他还要玩其他游戏,所以这个问题留给你解决. Input 第一行一个整数N,然后有N行,每行三个正整数a.b.k. N<=40000 , a.b.k<=10^9 Output 一个数,数列中所有元素的和 Sample Input 4 2 5

【BZOJ】4636: 蒟蒻的数列

4636: 蒟蒻的数列 Time Limit: 30 Sec  Memory Limit: 256 MBSubmit: 145  Solved: 71[Submit][Status][Discuss] Description 蒟蒻DCrusher不仅喜欢玩扑克,还喜欢研究数列 题目描述 DCrusher有一个数列,初始值均为0,他进行N次操作,每次将数列[a,b)这个区间中所有比k小的数改为k,他想知 道N次操作后数列中所有元素的和.他还要玩其他游戏,所以这个问题留给你解决. Input 第一行

BZOJ3786 星系探索 蒟蒻出题人给跪

本蒟蒻闲得蛋疼于是在BZOJ上加了一道水题,果然被瞬间水过... 只能说本蒟蒻实在是太弱了. Q:你为什么要写这篇博客? A:我只是为了水经验233.... 正常向的数据.题解.标程请自行传送下面的云盘... http://pan.baidu.com/s/1qWsMHM8 吐槽: 为什么本地不开O2 10s在OJ上开O2 还需要20+s啊!!!我本来不想卡常数好不好. 因为这个原因用数组实现数据结构被卡的请见谅...现在是40s应该卡不掉了. 另外如果发现自己被卡掉请重交一次.原因不解释. 为什

论蒟蒻的自我修养

作为一个蒟蒻,离开大神还有很大一段距离(更不用说神犇了).作为一个想成为SB的SX,自我修养是及其重要的.即使初三老师丧心病狂,也不能放弃这条路恩! 计划: 恩不去MO但是学习他们的那些书~~毕竟数学渣 = ^ = 然后是数据结构...我最弱的一块辣 然后是算法...我也不强 解题思路 啊啊啊!!!差得要命!!! 写程序 啊啊啊!!要死辣!! 所以要多写多练撒!! 要开始刷题了撒!! BZOJ的题目都不会啊!!要死了撒! 估计学一下MO还是有好处的..至少OI MO不分家~~MO主要是数论和排列

博主自传——蒟蒻的OI之路

博主来自河北石家庄市第二中学,现在读高二,主攻信息学竞赛(其实并没有学习其他学科竞赛). NOIP中人品大爆发,使劲挤进河北省一等奖队伍,侥幸留在竞赛团队中(差点就淘汰出局啦). 关于我的ID,YOUSIKI,就是那四个平假名,没有什么实际意义.若搜到日本某艺人,和我无关. NOIP前主要活跃在PekingUniversityOnlineJudge(不知道拼错木有),现在主要活跃在Lydsy(小伙伴们都叫他BZOJ). 在各个OJ上基本都有号(有大号也有小号),ID都是YOUSIKI.Tyvj,

【BZOJ-4636】蒟蒻的数列 动态开点线段树 ||(离散化) + 标记永久化

4636: 蒟蒻的数列 Time Limit: 30 Sec  Memory Limit: 256 MBSubmit: 247  Solved: 113[Submit][Status][Discuss] Description 蒟蒻DCrusher不仅喜欢玩扑克,还喜欢研究数列 题目描述 DCrusher有一个数列,初始值均为0,他进行N次操作,每次将数列[a,b)这个区间中所有比k小的数改为k,他想知 道N次操作后数列中所有元素的和.他还要玩其他游戏,所以这个问题留给你解决. Input 第一