Variable Letter Count Sort.

2018-03-19  本文已影响6人  R0b1n_L33

Θ(n) where n is the total letter count

def niblleLetterFromWords(words:[])->[]:
    # diff = 'a' - 1; 
    # As words starting with 'a' is stored underneath 
    # index 1 and so forth similarly.
    # Index 0 serve as a residency of NULL -- b''
    # So the scope of buckets is 27 which consists of
    # 1 bucket for b'' and the rest buckets for 
    # corresponding 26 alphabet letters.
    diff = 96
    scope = 27
    buckets = [[] for _ in range(scope)]
    for word in words:
        if not word:
            buckets[0].append(b'')
        else:
            buckets[word[0]-diff].append(word[1:])

    outcomes = buckets[0]
    # Do not deal with b'' set otherwise causing infinite loop
    for i in range(1,scope):
        bucket = buckets[i]
        lenOfBucket = len(bucket)
        if lenOfBucket > 0:
            sortedBucket = niblleLetterFromWords(bucket)
            prefix = (i+diff).to_bytes(1,byteorder='big')
            for i in range(lenOfBucket):
                sortedBucket[i] = prefix + sortedBucket[i]
            outcomes += sortedBucket
    return outcomes

def variableLetterCountSort()->[]:
    scope = 5
    amount = 100
    src = []
    # Build bytes via ASCII range of alphabet.
    alphabet = bytes(range(97, 123))
    for i in range(amount):
        src.append(bytes(choices(alphabet,k=randrange(scope))))
    return niblleLetterFromWords(src)
上一篇 下一篇

猜你喜欢

热点阅读