Loading [MathJax]/jax/output/HTML-CSS/jax.js
ac-library-hs-1.2.0.0: Data structures and algorithms
Safe HaskellSafe-Inferred
LanguageGHC2021

AtCoder.Extra.WaveletMatrix.Raw

Description

A static Wavelet Matrix without automatic index comperssion. Consider using AtCoder.Extra.WaveletMatrix instead.

Since: 1.1.0.0

Synopsis

RawWaveletMatrix

data RawWaveletMatrix Source #

A static Wavelet Matrix without automatic index comperssion.

Since: 1.1.0.0

Constructors

RawWaveletMatrix 

Fields

  • heightRwm :: !Int

    log2N.

    Since: 1.1.0.0

  • lengthRwm :: !Int

    The length of the original array.

    Since: 1.1.0.0

  • bitsRwm :: !(Vector BitVector)

    The bit matrix. Each row represents (heightRwm - 1 - iRow) bit's on/off.

    Since: 1.1.0.0

  • nZerosRwm :: !(Vector Int)

    The number of zeros bits in each row in the bit matrix.

    Since: 1.1.0.0

Constructors

build Source #

Arguments

:: HasCallStack 
=> Int

The number of different values in the compressed vector.

-> Vector Int

A compressed vector

-> RawWaveletMatrix

A wavelet matrix

O(nlogn) Creates a RawWaveletMatrix from a vector a.

Since: 1.1.0.0

Access (indexing)

access :: RawWaveletMatrix -> Int -> Maybe Int Source #

O(log|S|) Returns a[k] or Nothing if the index is out of the bounds. Try to use the original array if you can.

Since: 1.1.0.0

rank

rankLT :: RawWaveletMatrix -> Int -> Int -> Int -> Int Source #

O(log|S|) Returns the number of y in [l,r)×[0,y0).

Since: 1.1.0.0

rank Source #

Arguments

:: RawWaveletMatrix 
-> Int

l

-> Int

r

-> Int

y

-> Int

The number of y in [l,r).

O(log|S|) Returns the number of y in [l,r).

Since: 1.1.0.0

rankBetween Source #

Arguments

:: RawWaveletMatrix 
-> Int

l

-> Int

r

-> Int

y1

-> Int

y2

-> Int

The number of y in [l,r)×[y1,y2).

O(log|S|) Returns the number of y in [l,r)×[y1,y2).

Since: 1.1.0.0

Select

select :: RawWaveletMatrix -> Int -> Maybe Int Source #

O(log|S|) Returns the index of the first y in the sequence, or Nothing if y is not found.

Since: 1.1.0.0

selectKth Source #

Arguments

:: RawWaveletMatrix 
-> Int

k

-> Int

y

-> Maybe Int

The index of k-th y

O(log|S|) Returns the index of the k-th occurrence (0-based) of y, or Nothing if no such occurrence exists.

Since: 1.1.0.0

selectIn Source #

Arguments

:: RawWaveletMatrix

A wavelet matrix

-> Int

l

-> Int

r

-> Int

k

-> Maybe Int

The index of the first y in [l,r).

O(log|S|) Given an interval [l,r), it returns the index of the first occurrence (0-based) of y in the sequence, or Nothing if no such occurrence exists.

Since: 1.1.0.0

selectKthIn Source #

Arguments

:: RawWaveletMatrix 
-> Int

l

-> Int

r

-> Int

k

-> Int

y

-> Maybe Int

The index of the k-th y in [l,r).

O(log|S|) Given an interval [l,r), it returns the index of the k-th occurrence (0-based) of y in the sequence, or Nothing if no such occurrence exists.

Since: 1.1.0.0

Quantile (value-ordered access)

Safe (total)

kthSmallestIn Source #

Arguments

:: RawWaveletMatrix

A wavelet matrix

-> Int

l

-> Int

r

-> Int

k

-> Maybe Int

k-th largest y in [l,r)

O(log|S|) Given an interval [l,r), it returns the index of the k-th (0-based) smallest value. Note that duplicated values are counted as distinct occurrences.

Since: 1.1.0.0

ikthSmallestIn Source #

Arguments

:: RawWaveletMatrix 
-> Int

l

-> Int

r

-> Int

k

-> Maybe (Int, Int)

(i,y) for k-th largest y in [l,r)

O(log|S|) Given an interval [l,r), it returns both the index and the value of the k-th (0-based) smallest value. Note that duplicated values are counted as distinct occurrences.

Since: 1.1.0.0

kthLargestIn Source #

Arguments

:: RawWaveletMatrix

A wavelet matrix

-> Int

l

-> Int

r

-> Int

k

-> Maybe Int

k-th largest y in [l,r)

O(log|S|) Given an interval [l,r), it returns the index of the k-th (0-based) largest value. Note that duplicated values are counted as distinct occurrences.

Since: 1.1.0.0

ikthLargestIn Source #

Arguments

:: RawWaveletMatrix

A wavelet matrix

-> Int

l

-> Int

r

-> Int

k

-> Maybe (Int, Int)

(i,y) for k-th largest y in [l,r)

O(log|S|) Given an interval [l,r), it returns both the index and the value of the k-th (0-based) largest value. Note that duplicated values are counted as distinct occurrences.

Since: 1.1.0.0

Unsafe

unsafeKthSmallestIn :: RawWaveletMatrix -> Int -> Int -> Int -> Int Source #

O(loga)

Since: 1.1.0.0

unsafeIKthSmallestIn :: RawWaveletMatrix -> Int -> Int -> Int -> (Int, Int) Source #

O(loga)

Since: 1.1.0.0

unsafeKthLargestIn :: RawWaveletMatrix -> Int -> Int -> Int -> Int Source #

O(loga) Returns k-th (0-based) biggest number in [l,r). Note that duplicated values are counted as distinct occurrences.

Since: 1.1.0.0

unsafeIKthLargestIn :: RawWaveletMatrix -> Int -> Int -> Int -> (Int, Int) Source #

O(loga)

Since: 1.1.0.0

Lookup

lookupLE Source #

Arguments

:: RawWaveletMatrix

A wavelet matrix

-> Int

l

-> Int

r

-> Int

y0

-> Maybe Int

Maximum y in [l,r)×(,y0]

O(log|S|) Looks up the maximum y in [l,r)×(,y0].

Since: 1.1.0.0

lookupLT Source #

Arguments

:: RawWaveletMatrix 
-> Int

l

-> Int

r

-> Int

x

-> Maybe Int

Maximum y in [l,r)×(,y0)

O(loga) Finds the maximum x in [l,r) s.t. x0<x.

Since: 1.1.0.0

lookupGE Source #

Arguments

:: RawWaveletMatrix 
-> Int

l

-> Int

r

-> Int

y0

-> Maybe Int

Minimum y in [l,r)×[y0,).

O(log|S|) Looks up the minimum y in [l,r)×[y0,).

Since: 1.1.0.0

lookupGT Source #

Arguments

:: RawWaveletMatrix 
-> Int

l

-> Int

r

-> Int

y0

-> Maybe Int

Minimum y in [l,r)×(y0,)

O(log|S|) Looks up the minimum y in [l,r)×(y0,).

Since: 1.1.0.0

Conversions

assocsIn :: RawWaveletMatrix -> Int -> Int -> [(Int, Int)] Source #

O(min(|S|,L)log|S|) Collects (y,rank(y)) in range [l,r) in ascending order of y. Note that it's only fast when the |S| is very small.

Since: 1.1.0.0

assocsWith :: RawWaveletMatrix -> Int -> Int -> (Int -> Int) -> [(Int, Int)] Source #

O(logAmin(|A|,L)) Internal implementation of assocs.

Since: 1.1.0.0

descAssocsIn :: RawWaveletMatrix -> Int -> Int -> [(Int, Int)] Source #

O(min(|S|,L)log|S|) Collects (y,rank(y)) in range [l,r) in descending order of y. Note that it's only fast when the |S| is very small.

Since: 1.1.0.0

descAssocsInWith :: RawWaveletMatrix -> Int -> Int -> (Int -> Int) -> [(Int, Int)] Source #

O(logAmin(|A|,L)) Internal implementation of descAssoc.

Since: 1.1.0.0