Welcome to collectivesolver - Programming & Software Q&A with code examples. A website with trusted programming answers. All programs are tested and work.

Contact: aviboots(AT)netvision.net.il

Buy a domain name - Register cheap domain names from $0.99 - Namecheap

Scalable Hosting That Grows With You

Secure & Reliable Web Hosting, Free Domain, Free SSL, 1-Click WordPress Install, Expert 24/7 Support

Semrush - keyword research tool

Boost your online presence with premium web hosting and servers

Disclosure: My content contains affiliate links.

39,890 questions

51,821 answers

573 users

How to sort a list of 0s, 1s and 2s in Python

1 Answer

0 votes
def sort012List(lst) :
    lo = 0
    curr = 0
    hi = len(lst) - 1
    while (curr <= hi) :
        if lst[curr] == 0 :
            lst[lo], lst[curr] = lst[curr], lst[lo]
            lo += 1
            curr += 1
        elif lst[curr] == 1 :
            curr += 1
        elif lst[curr] == 2 :
            lst[curr], lst[hi] = lst[hi], lst[curr]
            hi -= 1
    return lst
        
        

lst = [1, 2, 2, 0, 1, 1, 0, 2, 0, 1, 0, 0, 1]

lst = sort012List(lst)

print(lst)



'''
run:

[0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 2, 2, 2]

'''

 



answered Apr 19, 2023 by avibootz

Related questions

1 answer 119 views
1 answer 154 views
1 answer 103 views
1 answer 117 views
1 answer 123 views
1 answer 129 views
1 answer 128 views
...