当前位置:网站首页>排序方法汇总(C语言)
排序方法汇总(C语言)
2022-08-02 14:14:00 【super阿真】
冒泡排序:
气泡排序,有时也被称为下沉排序,是一种简单的排序算法,它重复地穿过列表,比较相邻的元素,如果它们的顺序不对,就将它们交换。重复通过列表,直到列表被排序。
// C program for implementation of Bubble sort
#include <stdio.h>
void swap(int *xp, int *yp)
{
int temp = *xp;
*xp = *yp;
*yp = temp;
}
// A function to implement bubble sort
void bubbleSort(int arr[], int n)
{
int i, j;
for (i = 0; i < n-1; i++)
// Last i elements are already in place
for (j = 0; j < n-i-1; j++)
if (arr[j] > arr[j+1])
swap(&arr[j], &arr[j+1]);
}
/* Function to print an array */
void printArray(int arr[], int size)
{
int i;
for (i=0; i < size; i++)
printf("%d ", arr[i]);
printf("\n");
}
// Driver program to test above functions
int main()
{
int arr[] = {64, 34, 25, 12, 22, 11, 90};
int n = sizeof(arr)/sizeof(arr[0]); //想一想为什么要这么做?
bubbleSort(arr, n);
printf("Sorted array: \n");
printArray(arr, n);
return 0;
}
选择排序:
选择排序算法对一个数组进行排序,方法是反复从未排序的部分找到最小的元素(考虑升序)并将其放在开头。该算法在一个给定的数组中保持两个子数。
// C program for implementation of selection sort
#include <stdio.h>
void swap(int *xp, int *yp)
{
int temp = *xp;
*xp = *yp;
*yp = temp;
}
void selectionSort(int arr[], int n)
{
int i, j, min_idx;
// One by one move boundary of unsorted subarray
for (i = 0; i < n-1; i++)
{
// Find the minimum element in unsorted array
min_idx = i;
for (j = i+1; j < n; j++)
if (arr[j] < arr[min_idx])
min_idx = j;
// Swap the found minimum element with the first element
swap(&arr[min_idx], &arr[i]);
}
}
/* Function to print an array */
void printArray(int arr[], int size)
{
int i;
for (i=0; i < size; i++)
printf("%d ", arr[i]);
printf("\n");
}
// Driver program to test above functions
int main()
{
int arr[] = {64, 25, 12, 22, 11};
int n = sizeof(arr)/sizeof(arr[0]);
selectionSort(arr, n);
printf("Sorted array: \n");
printArray(arr, n);
return 0;
}
插入排序:
插入式排序是一种简单的排序算法,其工作方式类似于你对手中的扑克牌进行排序。数组实际上被分成了一个已排序的部分和一个未排序的部分。未排序部分的值被挑选出来,放在排序部分的正确位置上。
将一个大小为n的数组按升序排序。
1: 在数组上从arr[1]到arr[n]进行迭代。
2:将当前元素(键)与它的前一个元素进行比较。
3:如果关键元素比其前身小,则与之前的元素比较。将较大的元素向上移动一个位置,为被交换的元素腾出空间。
// C program for insertion sort
#include <math.h>
#include <stdio.h>
/* Function to sort an array using insertion sort*/
void insertionSort(int arr[], int n)
{
int i, key, j;
for (i = 1; i < n; i++) {
key = arr[i];
j = i - 1;
/* Move elements of arr[0..i-1], that are
greater than key, to one position ahead
of their current position */
while (j >= 0 && arr[j] > key) {
arr[j + 1] = arr[j];
j = j - 1;
}
arr[j + 1] = key;
}
}
// A utility function to print an array of size n
void printArray(int arr[], int n)
{
int i;
for (i = 0; i < n; i++)
printf("%d ", arr[i]);
printf("\n");
}
/* Driver program to test insertion sort */
int main()
{
int arr[] = { 12, 11, 13, 5, 6 };
int n = sizeof(arr) / sizeof(arr[0]);
insertionSort(arr, n);
printArray(arr, n);
return 0;
}
快速排序:
与合并排序一样,QuickSort也是一种分而治之的算法。它挑选一个元素作为支点,并围绕所挑选的支点分割给定的数组。QuickSort有许多不同的版本,它们以不同的方式挑选支点。
总是挑选第一个元素作为支点。
总是挑选最后一个元素作为支点(在下面实现)。
挑选一个随机元素作为支点。
挑选中位数作为支点。
quickSort的关键过程是partition()。分区的目标是,给定一个数组,以数组中的一个元素x为支点,将x放在排序后的数组中的正确位置,将所有较小的元素(比x小)放在x之前,将所有较大的元素(比x大)放在x之后,所有这些应该在线性时间内完成。
/* C++ implementation of QuickSort */
#include <bits/stdc++.h>
using namespace std;
// A utility function to swap two elements
void swap(int* a, int* b)
{
int t = *a;
*a = *b;
*b = t;
}
/* This function takes last element as pivot, places
the pivot element at its correct position in sorted
array, and places all smaller (smaller than pivot)
to left of pivot and all greater elements to right
of pivot */
int partition (int arr[], int low, int high)
{
int pivot = arr[high]; // pivot
int i = (low - 1); // Index of smaller element and indicates the right position of pivot found so far
for (int j = low; j <= high - 1; j++)
{
// If current element is smaller than the pivot
if (arr[j] < pivot)
{
i++; // increment index of smaller element
swap(&arr[i], &arr[j]);
}
}
swap(&arr[i + 1], &arr[high]);
return (i + 1);
}
/* The main function that implements QuickSort
arr[] --> Array to be sorted,
low --> Starting index,
high --> Ending index */
void quickSort(int arr[], int low, int high)
{
if (low < high)
{
/* pi is partitioning index, arr[p] is now
at right place */
int pi = partition(arr, low, high);
// Separately sort elements before
// partition and after partition
quickSort(arr, low, pi - 1);
quickSort(arr, pi + 1, high);
}
}
/* Function to print an array */
void printArray(int arr[], int size)
{
int i;
for (i = 0; i < size; i++)
cout << arr[i] << " ";
cout << endl;
}
// Driver Code
int main()
{
int arr[] = {10, 7, 8, 9, 1, 5};
int n = sizeof(arr) / sizeof(arr[0]);
quickSort(arr, 0, n - 1);
cout << "Sorted array: \n";
printArray(arr, n);
return 0;
}
// This code is contributed by rathbhupendra
快速排序的时间复杂度取决于输入数组和分区策略。
边栏推荐
猜你喜欢
MATLAB drawing command fimplicit detailed introduction to drawing implicit function graphics
Redis common interview questions
Test case exercises
你的站点可能还没有准备好用于Site KitSite Kit 无法访问 WordPress REST API。请确保其已在您的站点上启用。
Optisystem应用:光电检测器灵敏度建模
tcp transparent proxy (IP_TRANSPARENT)
【线程安全】用户级,内核级,组合级线程|线程同步的处理(条件变量)|strtok_r(可冲入函数)
分布式一致性协议-Raft
分布式一致性协议-Gossip
Detailed explanation of MATLAB drawing function fplot
随机推荐
光导布局设计工具
面试汇总
shader 和 ray marching
我的2021回忆录
px和em和rem的区别
Evaluate multipath BBR congestion control on ns3
【进程间通信】信号量的使用/共享内存
许多代码……
2021-06-06
Manifest merger failed : Attribute [email protected] value=
Run ns3 with multiple processes
Detailed introduction to the hierarchical method of binary tree creation
远程连接Ubuntu中的Mysql
5. Transaction management
计算机导论——数据库
开源一个golang写的游戏服务器框架
线性结构,顺序结构
LITESTAR 4D应用:室内植物照明模拟
字符数组/字符串数组|数组指针/指针数组/
剑指offer:合并两个排序的链表