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,931 questions

51,868 answers

573 users

How to sort an array of 0, 1 and 2 values with while loop and switch in C++

1 Answer

0 votes
#include <iostream>
 
using namespace std;
 
void swap(int *a, int *b) {
    int tmp;
      
    tmp = *b;
    *b = *a;
    *a = tmp;
}
   
void sort(int *arr, int len) {
    int start = 0, mid = 0, end = len - 1;   
      
    while (mid <= end) {
        switch (arr[mid]) {
            case 0:    
                swap(&arr[start], &arr[mid]);  
                start++;      
                mid++;     
                break;
            case 1:    
                mid++;    
                break;
            case 2:     
                swap(&arr[mid], &arr[end]);  
                end--;    
                break;
        }
    }
}
  
int main() {
    int arr[] = {2, 1, 0, 0, 1, 2, 2, 1, 1, 2};
    int len = sizeof(arr)/sizeof(arr[0]); 
  
    sort(arr, len);   
  
    for(int i = 0; i < len; i++)   
        cout << arr[i] << " ";
  
    return 0;
}
  
  
/*
run:
  
0 0 1 1 1 1 2 2 2 2 
  
*/

 



answered Apr 30, 2019 by avibootz
edited Apr 30, 2019 by avibootz
...