import random

def noisy_binary_search_and_insert(arr, x, mistake_probability):
    low = 0
    high = len(arr) - 1
    mid = 0
    indexes_checked_list = []

    while low <= high:
        mid = (high + low) // 2
        indexes_checked_list.append(mid)

        # Introduce noise in the comparison
        comparison_result = arr[mid] < x
        if random.random() < mistake_probability:  # With mistake probability p, invert the comparison result
            comparison_result = not comparison_result

        # Proceed based on potentially noisy comparison
        if comparison_result:
            low = mid + 1
        else:
            high = mid - 1

    # Insert x into the array
    # The position to insert is the 'low' index after the loop finishes
    array_copy = arr.copy()
    array_copy.insert(low, x)

    # low is the insert position and mid is the position of the last comparison
    return indexes_checked_list, array_copy, low

def noisy_binary_search_hacky(arr, x, queries_available, mistake_probability):
    upper_bound = len(arr)
    lower_bound = -1
    queries_thus_far = 0

    low = 0
    high = len(arr) - 1
    mid = 0
    indexes_checked_list = []

    while low <= high and queries_thus_far < queries_available:
        queries_thus_far += 1
        mid = (high + low) // 2
        indexes_checked_list.append(mid)

        # Introduce noise in the comparison
        actual_comparison = arr[mid] < x
        noisy_comparison = actual_comparison if random.random() >= mistake_probability else not actual_comparison

        # Proceed based on potentially noisy comparison
        if noisy_comparison:
            lower_bound = mid
            low = mid + 1
        else:
            upper_bound = mid
            high = mid - 1

    return indexes_checked_list, lower_bound, upper_bound


if __name__ == '__main__':
    max_number = 31
    mistake_probability = 0.0 

    sorted_list = [i for i in range(max_number)]

    for i in range(-1, max_number):
        element_to_insert = i + 0.5
        indexes_checked, new_array, insert_position = noisy_binary_search_and_insert(sorted_list, element_to_insert, mistake_probability)

        # Check if the new array is monotone
        for i in range(len(new_array) - 1):
            if not new_array[i] <= new_array[i + 1]: 
                print('Error: the new array is not monotone')
                exit(1)

        print('Array after insertion correct: ', new_array)

    print('Test passed!')

    
    test_list = [0, 1, 2, 3, 4, 5, 6, 7, 8]
    test_list.insert(0, 'a')
    print(test_list)
        

    
         