summaryrefslogtreecommitdiff
path: root/algorithms/bubble_sort.py
blob: f77ea08c9f407544a019b6ac0cf5e3a3eb902ddc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
import random
import string
CHARS = list(string.ascii_lowercase)
print(CHARS)
def generate_test_data(length: int, _range: tuple):
    arr = []
    for i in range(length):
        arr.append(random.randint(_range[0], _range[1]))
    return arr
def bubsort(arr: list):
    for i in range(len(arr)):
        # print(arr)
        changed = False
        for j in range(len(arr) - i - 1):
            if arr[j] > arr[j+1]:
                swp = arr[j+1]
                arr[j+1] = arr[j]
                arr[j] = swp
                changed = True
        if not changed: return arr 
def testarr_string(length: int):
    arr = []
    for i in range(length):
        string = ""
        for i in range(10):
            string += CHARS[random.randint(0,len(CHARS) - 1)]
        arr.append(string)
    print(arr)
    return arr
def bubsort_reliability(samples: int):
    y = 0
    n = 0
    for _ in range(samples):
        test  = generate_test_data(100, (0, 100))
        if bubsort(test) == sorted(test): y += 1
        else: n += 1
    if y == samples: print(f"{samples} checks passed!")
bubsort_reliability(100)
print(bubsort(testarr_string(10)))