<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha1/dist/css/bootstrap.min.css" rel="stylesheet"
        integrity="sha384-GLhlTQ8iRABdZLl6O3oVMWSktQOp6b7In1Zl3/Jr59b6EGGoI1aFkw7cmDA6j6gD" crossorigin="anonymous">
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.3.0/css/all.min.css"
        integrity="sha512-SzlrxWUlpfuzQ+pcUCosxcglQRNAq/DZjVsC0lE40xsADsfeQoEypE+enwcOiGjk/bSuGGKHEyjSoQ1zVisanQ=="
        crossorigin="anonymous" referrerpolicy="no-referrer" />
</head>
</html>
B
    ƒ fý	  ã               @   sZ   d Z ddd„Zddd„Zddd„Zdd	d
„ZyddlT W n ek
rL   Y nX eZeZdS )zBisection algorithms.é    Nc             C   sd   |dk rt dƒ‚|dkr t| ƒ}x2||k rR|| d }|| | k rH|}q"|d }q"W |  ||¡ dS )zïInsert item x in list a, and keep it sorted assuming a is sorted.

    If x is already in a, insert it to the right of the rightmost x.

    Optional args lo (default 0) and hi (default len(a)) bound the
    slice of a to be searched.
    r   zlo must be non-negativeNé   é   )Ú
ValueErrorÚlenÚinsert)ÚaÚxÚloÚhiÚmid© r   ú+/opt/alt/python37/lib64/python3.7/bisect.pyÚinsort_right   s    	
 r   c             C   sX   |dk rt dƒ‚|dkr t| ƒ}x2||k rR|| d }|| | k rH|}q"|d }q"W |S )a€  Return the index where to insert item x in list a, assuming a is sorted.

    The return value i is such that all e in a[:i] have e <= x, and all e in
    a[i:] have e > x.  So if x already appears in the list, a.insert(x) will
    insert just after the rightmost x already there.

    Optional args lo (default 0) and hi (default len(a)) bound the
    slice of a to be searched.
    r   zlo must be non-negativeNr   r   )r   r   )r   r   r	   r
   r   r   r   r   Úbisect_right   s    
 r   c             C   sd   |dk rt dƒ‚|dkr t| ƒ}x2||k rR|| d }| | |k rL|d }q"|}q"W |  ||¡ dS )zíInsert item x in list a, and keep it sorted assuming a is sorted.

    If x is already in a, insert it to the left of the leftmost x.

    Optional args lo (default 0) and hi (default len(a)) bound the
    slice of a to be searched.
    r   zlo must be non-negativeNr   r   )r   r   r   )r   r   r	   r
   r   r   r   r   Úinsort_left+   s    	
 
r   c             C   sX   |dk rt dƒ‚|dkr t| ƒ}x2||k rR|| d }| | |k rL|d }q"|}q"W |S )a€  Return the index where to insert item x in list a, assuming a is sorted.

    The return value i is such that all e in a[:i] have e < x, and all e in
    a[i:] have e >= x.  So if x already appears in the list, a.insert(x) will
    insert just before the leftmost x already there.

    Optional args lo (default 0) and hi (default len(a)) bound the
    slice of a to be searched.
    r   zlo must be non-negativeNr   r   )r   r   )r   r   r	   r
   r   r   r   r   Úbisect_left?   s    
 
r   )Ú*)r   N)r   N)r   N)r   N)	Ú__doc__r   r   r   r   Z_bisectÚImportErrorZbisectZinsortr   r   r   r   Ú<module>   s   



