The Full Counting Sort

Sort by

recency

|

715 Discussions

|

  • + 0 comments

    My answer in Typescript, noted

    function countSort(arr: string[][]): void {
        // create converted arr, fill with []
        let arr_converted = Array.from({ length: arr.length }, () => []);
    
        // forech element in [arr], add to [arr_converted]
        for (let i = 0; i < arr.length; i++) {
            let n = Number(arr[i][0])
            let c = i + 1 <= arr.length / 2 ? '-' : arr[i][1]
    
            arr_converted[n].push(c)
        }
    
        // print
        console.log(arr_converted.flat().join(' ').trim())
    }
    
  • + 0 comments

    Python

    def countSort(arr):
        for i in range(len(arr)//2):
            arr[i][1] = '-'
        arr.sort(key=lambda x: int(x[0]))
        [print(c[1], end=' ') for c in arr]
    
  • + 0 comments
    import java.io.*;
    import java.util.*;
    
    public class Solution {
    
        public static void main(String[] args) {
            Scanner sc = new Scanner(System.in);
            int n = sc.nextInt();
            int[] numbers = new int[n];
            int[] counter = new int[100];
            String[] s = new String[n];
            String[] orderedS = new String[n];
            StringBuilder out = new StringBuilder();
            for (int i = 0; i < n; i++) {
                numbers[i] = sc.nextInt();
                counter[numbers[i]]++;
                s[i] = sc.next();
            }
    
            for (int i = 1; i < 100; i++) { counter[i] += counter[i-1]; }
    
            for (int i = (n-1); i >= 0; i--) {
                if (i < n/2) {
                    orderedS[counter[numbers[i]] - 1] = "-";
                } else {
                    orderedS[counter[numbers[i]] - 1] = s[i];
                }
                counter[numbers[i]] -= 1;
            }
    
            for (int i = 0; i < n; i++) {
                out.append(orderedS[i] + " ");
            }
    
            System.out.print(out);
        }
    }
    
  • + 1 comment

    Finally, after 3 hours! Don't use Python's sort(): I assume that our memory usage is so constrained that we can't sort an array of 1000 things. Don't create a big string in memory (i.e. don't use join()). So:

    def count_sort_internal(a: list) -> list[str]:
        '''
        According to the examples online, this is how the 
        midpoint is calculated. The function is allowed
        to be destructive. 100 is the (exclusive) limit
        to the key.
        '''
        buckets = [[] for _ in range(100)]
        midpoint = len(a) // 2
        for i in range(midpoint):
            a[i][1] = '-'
        for i, (k, s) in enumerate(a):
            buckets[int(k)].append('-' if i < midpoint else s)
        result = [s for bucket in buckets for s in bucket]
        return result
    
    # pylint: disable=C0103,C0116
    def countSort(a: list):
        result = count_sort_internal(a)
        for i, s in enumerate(result):
            if i > 0:
                print(' ', end='')
            print(s, end='')
    
  • + 0 comments

    Python Solution:

    def countSort(arr):
        ans = [[] for _ in range(n)]
        for i in range(len(arr) // 2):
            ans[int(arr[i][0])].append("-")
        for i in range(len(arr) // 2, len(arr)):
            ans[int(arr[i][0])].append(arr[i][1])
        print(" ".join(" ".join(i) for i in ans).strip())