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
日前,国内知名主机服务商阿里云与国外资深服务器面板Plesk强强联合,推出 阿里云域名注册与备案、服务器ECS购买与登录使用 前言云服务器(Elastic 只需要确定cpu内存与带宽基本上就可以了,对于新手用户来说,我们在购买阿里云服务申请服务器与域名许多云服务商的云服务器配置是弹性的 三周学会小程序第三讲:服务 不过这个国外服务器有点慢,可以考虑国内的ngrokcc。 ngrokcc...
今天下午遇到一个网友聊到他昨天新注册的一个域名,今天在去使用的时候发现域名居然不见。开始怀疑他昨天是否付款扣费,以及是否有实名认证过,毕竟我们在国内域名注册平台注册域名是需要实名认证的,大概3-5天内如果不验证那是不可以使用的。但是如果注册完毕的域名找不到那也是奇怪。同时我也有怀疑他是不是忘记记错账户。毕竟我们有很多朋友在某个商家注册很多账户,有时候自己都忘记是用哪个账户的。但是我们去找账户也不办...
速云怎么样?速云,国人商家,提供广州移动、深圳移动、广州茂名联通、香港hkt等VDS和独立服务器。现在暑期限时特惠,力度大。广州移动/深圳移动/广东联通/香港HKT等9折优惠,最低月付9元;暑期特惠,带宽、流量翻倍,深港mplc免费试用!点击进入:速云官方网站地址速云优惠码:全场9折优惠码:summer速云优惠活动:活动期间,所有地区所有配置可享受9折优惠,深圳/广州地区流量计费VDS可选择流量翻...
byvoid为你推荐
saltstacksaltstack使用中的问题?master端sudo salt-master -l debug提示信息像这样,是什么情况?怎样改?bloomfilterJAVA怎么弄爬虫网关和路由器的区别网关和路由器的具体区别在哪里呀?mindmanager破解版求mindmanager 2019 的注册机webcrack我用WebCrack4 在破解路由器密码的时候为什么在破解密码的中途自动关闭掉电子日历怎样调整电子日历上的时间备忘录模式Java中常用的设计模式有哪些?请详细说明一下工厂模式。editplus破解版手机的常用软件和ngage的破解版editplus破解版DBTools Manager Professional 破解版在哪里可以下载?51信用卡论坛51信用卡怎么样?
汉邦高科域名注册 河南vps 中文域名申请 vmsnap3 tk域名 镇江联通宽带 嘟牛 个人免费空间 美国十次啦服务器 1g空间 免费智能解析 360云服务 空间首页登陆 空间登入 上海电信测速网站 www789 服务器论坛 网页加速 七牛云存储 网络速度 更多