K-Core算法 (文献笔记)

本文介绍了K-Core算法的概念,包括定义、特性以及算法实现。K-Core是一个嵌套结构,最大阶数的核称为主核,算法通过递归删除度数小于K的节点来找出K阶核。此外,还提到了算法的J语言实现伪代码,讨论了其复杂度优化的可能性。
摘要由CSDN通过智能技术生成

一:定义:
     设存在图G=(V,L)(V是结点们,L是边们)。定义n=|V|,m=|L|。则定义子图H=(W,L|W)当且仅当任意Degree_V(V属于H)>=k,且H是一个具有这样的属性的最大子图的时候,称H为结点集合W诱导的K-Core或者说一个K阶核。
一个图的最大阶数的核称为主核,一个结点的核阶数为包含此结点的K-Core的最大的K。
     不难发现K-Core 有以下特点:
                                            ①:是一个嵌套结构,小阶数的会嵌套大阶数的。即若i<j  则H_i必定包含H_j。

                                     ②:Core不一定是连接的子图。
    

 二:算法

  Ⅰ:输出每个结点所对应的最大阶数。

        递归删除所有度数小于K的结点,删除这个结点的同时删除和他相关联的边,剩下的子图便是一个K阶核。

        通过这个算法可以计算出每个结点属于几阶核。(求出每个结点是几阶核之后,就很容易判断不同阶数K-core分别由哪些结点组成的了,一个自身阶数为n的结点在所有k<=n的K-core中都会包含这个结点。所有求一个k-core直接就把所有的符合条件的结点组合成一个子图就可以了)

  • 1
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值