Skip to content
Snippets Groups Projects
cs_leaf.c 1.01 KiB
Newer Older
  • Learn to ignore specific revisions
  • Lubomir Riha's avatar
    Lubomir Riha committed
    #include "cs.h"
    /* consider A(i,j), node j in ith row subtree and return lca(jprev,j) */
    CS_INT cs_leaf (CS_INT i, CS_INT j, const CS_INT *first, CS_INT *maxfirst, CS_INT *prevleaf,
        CS_INT *ancestor, CS_INT *jleaf)
    {
        CS_INT q, s, sparent, jprev ;
        if (!first || !maxfirst || !prevleaf || !ancestor || !jleaf) return (-1) ;
        *jleaf = 0 ;
        if (i <= j || first [j] <= maxfirst [i]) return (-1) ;  /* j not a leaf */
        maxfirst [i] = first [j] ;      /* update max first[j] seen so far */
        jprev = prevleaf [i] ;          /* jprev = previous leaf of ith subtree */
        prevleaf [i] = j ;
        *jleaf = (jprev == -1) ? 1: 2 ; /* j is first or subsequent leaf */
        if (*jleaf == 1) return (i) ;   /* if 1st leaf, q = root of ith subtree */
        for (q = jprev ; q != ancestor [q] ; q = ancestor [q]) ;
        for (s = jprev ; s != q ; s = sparent)
        {
            sparent = ancestor [s] ;    /* path compression */
            ancestor [s] = q ;
        }
        return (q) ;                    /* q = least common ancester (jprev,j) */
    }