function tarjanHelper(u, adjMatrix, index, indices, lowlink, onStack, stack, sccs)
    index = index + 1;
    indices(u) = index;
    lowlink(u) = index;
    stack = [stack, u];
    onStack(u) = true;

    neighbors = find(adjMatrix(u, :) > 0); % 获取邻居节点
    for v = neighbors
        if indices(v) == 0
            tarjanHelper(v, adjMatrix, index, indices, lowlink, onStack, stack, sccs);
            lowlink(u) = min(lowlink(u), lowlink(v));
        elseif onStack(v)
            lowlink(u) = min(lowlink(u), indices(v));
        end
    end

    if lowlink(u) == indices(u)
        scc = [];
        while ~isempty(stack) && stack(end) ~= u
            v = stack(end);
            stack(end) = [];
            onStack(v) = false;
            scc = [scc, v];
        end
        stack(end) = [];
        onStack(u) = false;
        scc = [scc, u];
        sccs{end+1} = scc;
    end
end