How to implement counting sorting algorithm in C#
How to implement the counting sort algorithm in C
#Counting sort is a simple but effective sorting algorithm that can achieve O(n k) time complexity Sort a set of integers, where n is the number of elements to be sorted and k is the range of elements to be sorted.
The basic idea of counting sorting is to create an auxiliary array to count the number of occurrences of each element in the sequence to be sorted. Then, by performing a sum operation on the auxiliary array, the position of each element in the ordered sequence is obtained. Finally, based on the statistical results of the auxiliary array, the elements are put back into the original array to complete the sorting.
The following is a specific code example for implementing the counting sorting algorithm in C#:
using System; class CountingSort { public static void Sort(int[] array) { if (array == null || array.Length == 0) { return; } // 找到待排序序列中的最大值和最小值 int min = array[0]; int max = array[0]; for (int i = 1; i < array.Length; i++) { if (array[i] < min) { min = array[i]; } if (array[i] > max) { max = array[i]; } } // 创建辅助数组count,用于统计待排序序列中每个元素的出现次数 int[] count = new int[max - min + 1]; // 统计每个元素的出现次数 for (int i = 0; i < array.Length; i++) { count[array[i] - min]++; } // 对辅助数组进行求和操作,得到每个元素在有序序列中的位置 for (int i = 1; i < count.Length; i++) { count[i] += count[i - 1]; } // 创建临时数组,用于存储排序结果 int[] sortedArray = new int[array.Length]; // 根据辅助数组的统计结果,将元素放回原始数组中 for (int i = array.Length - 1; i >= 0; i--) { int index = count[array[i] - min] - 1; sortedArray[index] = array[i]; count[array[i] - min]--; } // 将排序结果拷贝回原始数组 Array.Copy(sortedArray, array, array.Length); } // 测试计数排序算法 static void Main(string[] args) { int[] array = { 5, 2, 9, 3, 1, 6, 8, 4, 7 }; Console.WriteLine("原始数组:"); PrintArray(array); Sort(array); Console.WriteLine("排序结果:"); PrintArray(array); } // 打印数组 static void PrintArray(int[] array) { foreach (int element in array) { Console.Write(element + " "); } Console.WriteLine(); } }
In the above code, we first find the maximum and minimum values in the sequence to be sorted, and then create the auxiliary array count to Count the occurrences of each element. Next, the position of each element in the ordered sequence is obtained by performing a sum operation on the auxiliary array. Finally, based on the statistical results of the auxiliary array, the elements are put back into the original array to complete the sorting.
In the test code, we use a sample array to test the counting sort algorithm. The output shows the original array and the sorted results.
Through the above code examples, we can understand how to implement the counting sorting algorithm in C#. Counting sort is a simple but effective sorting algorithm, especially suitable for situations where the range of elements in the sequence to be sorted is small. By mastering the principles and implementation of counting sorting algorithms, we can choose the most suitable sorting algorithm when sorting is needed and improve the efficiency of the program.
The above is the detailed content of How to implement counting sorting algorithm in C#. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



The usage methods of symbols in C language cover arithmetic, assignment, conditions, logic, bit operators, etc. Arithmetic operators are used for basic mathematical operations, assignment operators are used for assignment and addition, subtraction, multiplication and division assignment, condition operators are used for different operations according to conditions, logical operators are used for logical operations, bit operators are used for bit-level operations, and special constants are used to represent null pointers, end-of-file markers, and non-numeric values.

In C, the char type is used in strings: 1. Store a single character; 2. Use an array to represent a string and end with a null terminator; 3. Operate through a string operation function; 4. Read or output a string from the keyboard.

In C language, special characters are processed through escape sequences, such as: \n represents line breaks. \t means tab character. Use escape sequences or character constants to represent special characters, such as char c = '\n'. Note that the backslash needs to be escaped twice. Different platforms and compilers may have different escape sequences, please consult the documentation.

In C language, the main difference between char and wchar_t is character encoding: char uses ASCII or extends ASCII, wchar_t uses Unicode; char takes up 1-2 bytes, wchar_t takes up 2-4 bytes; char is suitable for English text, wchar_t is suitable for multilingual text; char is widely supported, wchar_t depends on whether the compiler and operating system support Unicode; char is limited in character range, wchar_t has a larger character range, and special functions are used for arithmetic operations.

The difference between multithreading and asynchronous is that multithreading executes multiple threads at the same time, while asynchronously performs operations without blocking the current thread. Multithreading is used for compute-intensive tasks, while asynchronously is used for user interaction. The advantage of multi-threading is to improve computing performance, while the advantage of asynchronous is to not block UI threads. Choosing multithreading or asynchronous depends on the nature of the task: Computation-intensive tasks use multithreading, tasks that interact with external resources and need to keep UI responsiveness use asynchronous.

In C language, char type conversion can be directly converted to another type by: casting: using casting characters. Automatic type conversion: When one type of data can accommodate another type of value, the compiler automatically converts it.

There is no built-in sum function in C language, so it needs to be written by yourself. Sum can be achieved by traversing the array and accumulating elements: Loop version: Sum is calculated using for loop and array length. Pointer version: Use pointers to point to array elements, and efficient summing is achieved through self-increment pointers. Dynamically allocate array version: Dynamically allocate arrays and manage memory yourself, ensuring that allocated memory is freed to prevent memory leaks.

The char array stores character sequences in C language and is declared as char array_name[size]. The access element is passed through the subscript operator, and the element ends with the null terminator '\0', which represents the end point of the string. The C language provides a variety of string manipulation functions, such as strlen(), strcpy(), strcat() and strcmp().
