def test_reverse_bisect_left(): assert reverse_bisect_left([], 0) == 0 assert reverse_bisect_left([1], -1) == 1 assert reverse_bisect_left([1], 0) == 1 assert reverse_bisect_left([1], 1) == 0 assert reverse_bisect_left([1], 2) == 0 assert reverse_bisect_left([2, 1], -1) == 2 assert reverse_bisect_left([2, 1], 0) == 2 assert reverse_bisect_left([2, 1], 1) == 1 assert reverse_bisect_left([2, 1], 2) == 0 assert reverse_bisect_left([2, 1], 3) == 0 assert reverse_bisect_left([3, 2, 1], -1) == 3 assert reverse_bisect_left([3, 2, 1], 0) == 3 assert reverse_bisect_left([3, 2, 1], 1) == 2 assert reverse_bisect_left([3, 2, 1], 2) == 1 assert reverse_bisect_left([3, 2, 1], 3) == 0 assert reverse_bisect_left([3, 2, 1], 4) == 0 assert reverse_bisect_left([4, 3, 2, 1], -1) == 4 assert reverse_bisect_left([4, 3, 2, 1], 0) == 4 assert reverse_bisect_left([4, 3, 2, 1], 1) == 3 assert reverse_bisect_left([4, 3, 2, 1], 2) == 2 assert reverse_bisect_left([4, 3, 2, 1], 3) == 1 assert reverse_bisect_left([4, 3, 2, 1], 4) == 0 assert reverse_bisect_left([4, 3, 2, 1], 5) == 0 assert reverse_bisect_left([1, 1], 0) == 2 assert reverse_bisect_left([1, 1], 1) == 0 assert reverse_bisect_left([1, 1], 2) == 0 assert reverse_bisect_left([2, 1, 1], 0) == 3 assert reverse_bisect_left([2, 1, 1], 1) == 1 assert reverse_bisect_left([2, 1, 1], 2) == 0 assert reverse_bisect_left([2, 2, 1], 0) == 3 assert reverse_bisect_left([2, 2, 1], 1) == 2 assert reverse_bisect_left([2, 2, 1], 2) == 0 assert reverse_bisect_left([3, 2, 1], 2, hi=10) == 1
def test_reverse_bisect_left(): assert reverse_bisect_left([], 0) == 0 assert reverse_bisect_left([1], -1) == 1 assert reverse_bisect_left([1], 0) == 1 assert reverse_bisect_left([1], 1) == 0 assert reverse_bisect_left([1], 2) == 0 assert reverse_bisect_left([2, 1], -1) == 2 assert reverse_bisect_left([2, 1], 0) == 2 assert reverse_bisect_left([2, 1], 1) == 1 assert reverse_bisect_left([2, 1], 2) == 0 assert reverse_bisect_left([2, 1], 3) == 0 assert reverse_bisect_left([3, 2, 1], -1) == 3 assert reverse_bisect_left([3, 2, 1], 0) == 3 assert reverse_bisect_left([3, 2, 1], 1) == 2 assert reverse_bisect_left([3, 2, 1], 2) == 1 assert reverse_bisect_left([3, 2, 1], 3) == 0 assert reverse_bisect_left([3, 2, 1], 4) == 0 assert reverse_bisect_left([4, 3, 2, 1], -1) == 4 assert reverse_bisect_left([4, 3, 2, 1], 0) == 4 assert reverse_bisect_left([4, 3, 2, 1], 1) == 3 assert reverse_bisect_left([4, 3, 2, 1], 2) == 2 assert reverse_bisect_left([4, 3, 2, 1], 3) == 1 assert reverse_bisect_left([4, 3, 2, 1], 4) == 0 assert reverse_bisect_left([4, 3, 2, 1], 5) == 0 assert reverse_bisect_left([1, 1], 0) == 2 assert reverse_bisect_left([1, 1], 1) == 0 assert reverse_bisect_left([1, 1], 2) == 0 assert reverse_bisect_left([2, 1, 1], 0) == 3 assert reverse_bisect_left([2, 1, 1], 1) == 1 assert reverse_bisect_left([2, 1, 1], 2) == 0 assert reverse_bisect_left([2, 2, 1], 0) == 3 assert reverse_bisect_left([2, 2, 1], 1) == 2 assert reverse_bisect_left([2, 2, 1], 2) == 0