Clasificación de casillero

La clasificación por casilleros es un algoritmo de clasificación que es adecuado para clasificar listas de elementos donde el número de elementos y el número de valores clave posibles son aproximadamente los mismos. 
Requiere tiempo O ( n + Rango ), donde n es el número de elementos en la array de entrada y ‘Rango’ es el número de valores posibles en la array. 
Funcionamiento del algoritmo: 
 

C++

/* C program to implement Pigeonhole Sort */
#include <bits/stdc++.h>
using namespace std;
  
/* Sorts the array using pigeonhole algorithm */
void pigeonholeSort(int arr[], int n)
{
    // Find minimum and maximum values in arr[]
    int min = arr[0], max = arr[0];
    for (int i = 1; i < n; i++)
    {
        if (arr[i] < min)
            min = arr[i];
        if (arr[i] > max)
            max = arr[i];
    }
    int range = max - min + 1; // Find range
  
    // Create an array of vectors. Size of array
    // range. Each vector represents a hole that
    // is going to contain matching elements.
    vector<int> holes[range];
  
    // Traverse through input array and put every
    // element in its respective hole
    for (int i = 0; i < n; i++)
        holes[arr[i]-min].push_back(arr[i]);
  
    // Traverse through all holes one by one. For
    // every hole, take its elements and put in
    // array.
    int index = 0;  // index in sorted array
    for (int i = 0; i < range; i++)
    {
       vector<int>::iterator it;
       for (it = holes[i].begin(); it != holes[i].end(); ++it)
            arr[index++]  = *it;
    }
}
  
// Driver program to test the above function
int main()
{
    int arr[] = {8, 3, 2, 7, 4, 6, 8};
    int n = sizeof(arr)/sizeof(arr[0]);
  
    pigeonholeSort(arr, n);
  
    printf("Sorted order is : ");
    for (int i = 0; i < n; i++)
        printf("%d ", arr[i]);
  
    return 0;
}

Java

/* Java program to implement Pigeonhole Sort */
  
import java.lang.*;
import java.util.*;
  
public class GFG
{
    public static void pigeonhole_sort(int arr[],
                                           int n)
    {
        int min = arr[0];
        int max = arr[0];
        int range, i, j, index; 
  
        for(int a=0; a<n; a++)
        {
            if(arr[a] > max)
                max = arr[a];
            if(arr[a] < min)
                min = arr[a];
        }
  
        range = max - min + 1;
        int[] phole = new int[range];
        Arrays.fill(phole, 0);
  
        for(i = 0; i<n; i++)
            phole[arr[i] - min]++;
  
          
        index = 0;
  
        for(j = 0; j<range; j++)
            while(phole[j]-->0)
                arr[index++]=j+min;
  
    }
  
    public static void main(String[] args)
    {
        GFG sort = new GFG();
        int[] arr = {8, 3, 2, 7, 4, 6, 8};
  
        System.out.print("Sorted order is : ");
  
        sort.pigeonhole_sort(arr,arr.length);
          
        for(int i=0 ; i<arr.length ; i++)
            System.out.print(arr[i] + " ");
    }
  
}
  
// Code contributed by Mohit Gupta_OMG <(0_o)>

Python3

# Python program to implement Pigeonhole Sort */
  
# source code : "https://en.wikibooks.org/wiki/
#   Algorithm_Implementation/Sorting/Pigeonhole_sort"
def pigeonhole_sort(a):
    # size of range of values in the list 
    # (ie, number of pigeonholes we need)
    my_min = min(a)
    my_max = max(a)
    size = my_max - my_min + 1
  
    # our list of pigeonholes
    holes = [0] * size
  
    # Populate the pigeonholes.
    for x in a:
        assert type(x) is int, "integers only please"
        holes[x - my_min] += 1
  
    # Put the elements back into the array in order.
    i = 0
    for count in range(size):
        while holes[count] > 0:
            holes[count] -= 1
            a[i] = count + my_min
            i += 1
              
  
a = [8, 3, 2, 7, 4, 6, 8]
print("Sorted order is : ", end = ' ')
  
pigeonhole_sort(a)
          
for i in range(0, len(a)):
    print(a[i], end = ' ')
     

C#

// C# program to implement
// Pigeonhole Sort 
using System;
  
class GFG
{
public static void pigeonhole_sort(int []arr,
                                   int n)
{
    int min = arr[0];
    int max = arr[0];
    int range, i, j, index; 
  
    for(int a = 0; a < n; a++)
    {
        if(arr[a] > max)
            max = arr[a];
        if(arr[a] < min)
            min = arr[a];
    }
  
    range = max - min + 1;
    int[] phole = new int[range];
      
    for(i = 0; i < n; i++)
    phole[i] = 0;
  
    for(i = 0; i < n; i++)
        phole[arr[i] - min]++;
  
      
    index = 0;
  
    for(j = 0; j < range; j++)
        while(phole[j] --> 0)
            arr[index++] = j + min;
  
}
  
// Driver Code
static void Main()
{
    int[] arr = {8, 3, 2, 7, 
                 4, 6, 8};
  
    Console.Write("Sorted order is : ");
  
    pigeonhole_sort(arr,arr.Length);
      
    for(int i = 0 ; i < arr.Length ; i++)
        Console.Write(arr[i] + " ");
}
}
  
// This code is contributed
// by Sam007

Javascript

<script>
  
// JavaScript program to implement
// Pigeonhole Sort
  
function pigeonhole_sort(arr, n)
{
    let min = arr[0];
    let max = arr[0];
    let range, i, j, index; 
    
    for(let a = 0; a < n; a++)
    {
        if(arr[a] > max)
            max = arr[a];
        if(arr[a] < min)
            min = arr[a];
    }
    
    range = max - min + 1;
    let phole = [];
        
    for(i = 0; i < n; i++)
    phole[i] = 0;
    
    for(i = 0; i < n; i++)
        phole[arr[i] - min]++;
    
        
    index = 0;
    
    for(j = 0; j < range; j++)
        while(phole[j] --> 0)
            arr[index++] = j + min;
    
}
  
// Driver Code
  
    let arr = [8, 3, 2, 7, 
                 4, 6, 8];
    
    document.write("Sorted order is : ");
    
    pigeonhole_sort(arr,arr.length);
        
    for(let i = 0 ; i < arr.length ; i++)
        document.write(arr[i] + " ");
      
    // This code is contributed by target_2.
</script>

Publicación traducida automáticamente

Artículo escrito por GeeksforGeeks-1 y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *