byvoidjs中有哪些全局方法?
byvoid 时间:2021-07-10 阅读:(
)
BAT前端应届生的薪资大概有多少
我毕业的时候(08年) 腾讯7k 百度9k,麦克尔索芙特也就13k(貌似阿里当时更低完全没入眼)
今年出去面试,听完工资范围面试官都嫉妒得无心招聘了……
话说阿里的实习生分 Ali star(比如之前很火的byvoid小朋友面试记录泄漏),A+,A,B+四档,一般入目。
Pascal 的tarjan算法
强连通分量
一个有向图中,如果节点i能够通过一些边到达节点j,就 简写成i能到达j。
如果对于任意两个节点i,j均有i能到达j或j能到达i,则说此图是连通的。
如果对于任意两个节点i,j均有i能到达j且j能到达i, 则说此图是强连通的。
对于一个无向图,说强联通没有意义,因为此时强连通就是连通。
而对于一个有向图,它不一定是强连通的,但可以分为几个极大的 强连通子图(“极大”的意思是再加入任何一个顶点就不满足强连通了)。
这些子图叫做这个有向图的强连通分量。
在上图中,强连通分量是 A{1},B{2,4},C{3,5,6,7}。
在一个强连通分量中的节点由于有着相似的拓扑性质,所以我们可以将其紧缩为一个节点(这让我想到了什么?化 学里的“族”),于是就大大减小了图的规模。
比如上图紧缩为A,B,C三个节点后,整个图就成为了B←A→C的简单形式。
所以强连通分量是一个 很有意义的东西。
然而如果根据定义,对每个节点进行一次O(n2)的DFS以求出它所能到达的顶点的话,整 个算法的时间复杂度就是迟钝的O(n3)。
下面将介绍用O(n2)求强连通分量的算 法:Tarjan算法。
Tarjan算法
Tarjan算法只要一遍DFS,效率高于Kosaraju。
它在技术上有了很大改进。
它基于的思想是:强连通分量是 DFS树中的子树(无论你如何进行DFS)。
Tarjan算法的过程是:
①在DFS树中,设low[x]是x或x的后代能够达到的最高的 祖先。
初始化时low[x]设为x。
②进行DFS,在结束节点x时计算low[x]。
计算的方法是:找出x能够到达的所有节点i,应保证 low[i]是x的祖先,即low[i]是灰点。
low[x]=highest(low[i]),即d[low[i]]最小。
③若 low[x]=x,则以x为根的子树就是一个强连通分量,输出并将其从树中删去。
我们依次得出:
low[4]=low[2]=2
low[2]=low[4]=2 //{4,2}为强 连通分量
low[5]=low[3]=3
low[7]=low[5]=3
low[6]=low[7]=3
low[3]=low[6]=3 //{5,7,6,3}为强连通分量
low[1]=1 //{1}为强连通分量
程 序:
var a,kl:array[1..1000,1..1000]of longint;
d,f,low,stack:array[1..1000]of longint;
i,j,n,time,h:longint;
procedure dfs(x:longint);
var i:longint;
begin
inc(time);
d[x]:=time;
inc(h);
stack[h]:=x;
for i:=1 to n do
if a[x,i]>0 then
begin
if d[i]=0 then
begin
kl[x,i]:=1;
dfs(i);
end;
if (d[i]>0)and(f[i]=0) then kl[x,i]:=2;
if f[i]>0 then
begin
if d[x]>d[i] then kl[x,i]:=3 else kl[x,i]:=4;
end;
end;
inc(time);
f[x]:=time;
for i:=1 to n do
if a[x,i]>0 then
if (f[low[i]]=0)and(d[low[i]]<d[low[x]])and(d[low[i]]>0) then
low[x]:=low[i];
if low[x]=x then
begin
while stack[h]<>x do
begin
write(stack[h],);
dec(h);
end;
writeln(stack[h]);
dec(h);
end;
end;
begin
readln(n);
for i:=1 to n do
begin
for j:=1 to n do read(a[i,j]);
readln;
end;
fillchar(d,sizeof(d),0);
fillchar(d,sizeof(d),0);
for i:=1 to n do low[i]:=i;
time:=0;
fillchar(stack,sizeof(stack),0);
h:=0;
for i:=1 to n do
if d[i]=0 then dfs(i);
end.
还有,在BYVoid神牛的Blog里也讲到了Tarjan算法(图文并茂啊。
。
我就是看这个学的)。
js中有哪些全局方法?
类: Array, Boolean Date Error Number Object RegExp String
这些类有自己的方法, 生成对象后就可以用
方法: decodeURI decodeURIComponent encodeURI encodeURIComponent eval isFinite isNaN parseFloat parseInt
蓝速数据金秋上云季2G58/年怎么样?蓝速数据物理机拼团0元购劲爆?蓝速数据服务器秒杀爆产品好不好?蓝速数据是广州五联科技信息有限公司旗下品牌云计算平台、采用国内首选Zkeys公有云建设多种开通方式、具有IDC、ISP从业资格证IDC运营商新老用户值得信赖的商家。我司主要从事内地的枣庄、宿迁、深圳、绍兴、成都(市、县)。待开放地区:北京、广州、十堰、西安、镇江(市、县)。等地区数据中心业务,均KV...
官方网站:点击访问王小玉网络官网活动方案:买美国云服务器就选MF.0220.CN 实力 强 强 强!!!杭州王小玉网络 旗下 魔方资源池 “我亏本你引流活动 ” mf.0220.CNCPU型号内存硬盘美国CERA机房 E5 2696v2 2核心8G30G总硬盘1个独立IP19.9元/月 续费同价mf.0220.CN 购买湖北100G防御 E5 2690v2 4核心4G...
justhost怎么样?justhost是一家俄罗斯主机商,2006年成立,提供各种主机服务,vps基于kvm,有HDD和SSD硬盘两种,特色是200Mbps不限流量(之前是100Mbps,现在升级为200Mbps)。下面是HDD硬盘的KVM VPS,性价比最高,此外还有SSD硬盘的KVM VPS,价格略高。支持Paypal付款。国内建议选择新西伯利亚或者莫斯科DataLine。支持Paypal付...
byvoid为你推荐
策略组简述组策略的概念 急急急空白代码html空格代码怎么写oncontextmenu鼠标右键很好用,但是左键一点反应也没有,请问是什么原因呢?oracle索引什么是Oracle的函数索引?备忘录模式为什么我的华为手机界面总是有个框框在备忘录上面调度系统1.说明高级调度、中级调度和低级调度的基本含义。flowplayer如何编译flowplayer源码spawningvc出现error spawning c1.exe怎么解决?民生电商陆金所、民生电商哪个更适合投资?ruby语言Ruby是一种什么样的语言,主要用来做什么,现在有一家公司让我从java转ruby,我很犹豫?
服务器评测 163网 paypal认证 mobaxterm 服务器架设 华为网络硬盘 空间出租 已备案删除域名 91vps 中国电信测网速 速度云 最漂亮的qq空间 服务器是干什么用的 德隆中文网 游戏服务器出租 百度云空间 lamp怎么读 服务器硬件配置 移动王卡 SmartAXMT800 更多