The sort function in C is a functional function used to sort the elements in an array or container. Sorting can be in ascending or descending order, and various types of data such as integer, floating point, and character types can be sorted. C language provides multiple sorting functions. This article will introduce the usage and characteristics of these sorting functions in detail.
- sort() function
The sort() function is one of the most commonly used sorting functions in C STL. Its function is to arrange the elements in an array or container. . The basic usage of the sort() function is as follows:
sort(begin, end);
Among them, begin is the address of the first element in the array or container, and end is the address 1 of the last element, so end points to the empty address after the last element. . The sort() function sorts in ascending order by default. If you need to sort in descending order, you can pass in a function pointer or lambda expression as the third parameter.
The following is a sample code that demonstrates how to use the sort() function to sort an integer array:
#include <iostream> #include <algorithm> using namespace std; int main() { int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7}; int n = sizeof(arr) / sizeof(arr[0]); sort(arr, arr + n); for (int i = 0; i < n; i++) { cout << arr[i] << " "; } return 0; }
The result of running the above code is as follows:
1 2 3 4 5 6 7 8 9
- stable_sort() function
stable_sort() function is similar to sort() function, but it ensures that the relative positions of elements with the same value remain unchanged after sorting. The usage of the stable_sort() function is similar to the sort() function. You can also pass in a function pointer or lambda expression as the third parameter. The following is a sample code:
#include <iostream> #include <algorithm> using namespace std; int main() { int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7}; int n = sizeof(arr) / sizeof(arr[0]); stable_sort(arr, arr + n); for (int i = 0; i < n; i++) { cout << arr[i] << " "; } return 0; }
The result of running the above code is as follows:
1 2 3 4 5 6 7 8 9
- partial_sort() function
partial_sort() function can convert an array or The elements in the container are partially sorted, that is, the top k smallest elements are sorted in front of the array (or the top k largest elements are sorted in front of the array). The usage is as follows:
partial_sort(begin, middle, end);
where begin is the address of the first element in the array or container, end is the address 1 of the last element, and middle is an iterator pointing to the k-th element. It should be noted that the partial_sort() function only guarantees that the first k elements are in order, and the order of the remaining elements is undefined. The following is a sample code:
#include <iostream> #include <algorithm> using namespace std; int main() { int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7}; int n = sizeof(arr) / sizeof(arr[0]); int k = 3; partial_sort(arr, arr + k, arr + n); for (int i = 0; i < k; i++) { cout << arr[i] << " "; } return 0; }
The result of running the above code is as follows:
1 2 3
- nth_element() function
nth_element() function is used to select an array Or the kth smallest (or kth largest) element in the container and arrange it at the kth position in the array. The usage is as follows:
nth_element(begin, middle, end);
where begin is the address of the first element in the array or container, end is the address 1 of the last element, and middle is an iterator pointing to the k-th element. It should be noted that the nth_element() function only guarantees that the first k elements of the array are ordered, while the kth element is unsorted. The following is a sample code:
#include <iostream> #include <algorithm> using namespace std; int main() { int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7}; int n = sizeof(arr) / sizeof(arr[0]); int k = 3; nth_element(arr, arr + k - 1, arr + n); cout << "第 " << k << " 小的数是:" << arr[k - 1] << endl; return 0; }
The result of running the above code is as follows:
第 3 小的数是:3
- make_heap() function
make_heap() function can convert an array or The container is converted into a heap, that is, the elements in the array are sorted according to the rules of the binary heap to support heap operations. The usage is as follows:
make_heap(begin, end);
where begin is the address of the first element in the array or container, and end is the address of the last element 1. The following is a sample code:
#include <iostream> #include <algorithm> using namespace std; int main() { int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7}; int n = sizeof(arr) / sizeof(arr[0]); make_heap(arr, arr + n); for (int i = 0; i < n; i++) { cout << arr[i] << " "; } return 0; }
The result of running the above code is as follows:
9 7 8 6 4 3 5 1 2
- push_heap() function
push_heap() function can push a new Elements are inserted into the heap and the structure of the heap is restructured to suit the properties of the heap. The usage is as follows:
push_heap(begin, end);
where begin is the address of the first element in the array or container, and end is the address of the last element. It should be noted that the inserted new element should be placed at the last position of the heap. The following is a sample code:
#include <iostream> #include <algorithm> using namespace std; int main() { int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7}; int n = sizeof(arr) / sizeof(arr[0]); make_heap(arr, arr + n); arr[n] = 0; push_heap(arr, arr + n + 1); for (int i = 0; i < n + 1; i++) { cout << arr[i] << " "; } return 0; }
The result of running the above code is as follows:
9 7 8 6 4 3 5 1 2 0
- pop_heap() function
pop_heap() function is used to convert the heap The top element pops out and the heap is restructured to suit the nature of the heap. The usage is as follows:
pop_heap(begin, end);
where begin is the address of the first element in the array or container, and end is the address of the last element. It should be noted that after popping the top element of the heap, the size of the heap should be reduced by 1. The following is a sample code:
#include <iostream> #include <algorithm> using namespace std; int main() { int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7}; int n = sizeof(arr) / sizeof(arr[0]); make_heap(arr, arr + n); pop_heap(arr, arr + n); n--; for (int i = 0; i < n; i++) { cout << arr[i] << " "; } return 0; }
The result of running the above code is as follows:
8 7 5 6 4 3 2 1
- sort_heap() function
sort_heap() function is used to sort the heap Sort and ensure that the sorted array is in ascending order. The usage is as follows:
sort_heap(begin, end);
where begin is the address of the first element in the array or container, and end is the address of the last element. It should be noted that the sort_heap() function will first call the pop_heap() function to pop the top element of the heap before sorting the heap, so the size of the sorted array should be reduced by 1. The following is a sample code:
#include <iostream> #include <algorithm> using namespace std; int main() { int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7}; int n = sizeof(arr) / sizeof(arr[0]); make_heap(arr, arr + n); sort_heap(arr, arr + n); for (int i = 0; i < n; i++) { cout << arr[i] << " "; } return 0; }
The result of running the above code is as follows:
1 2 3 4 5 6 7 8 9
Summary
This article introduces in detail the common sorting functions in C, including sort(), stable_sort (), partial_sort(), nth_element(), make_heap(), push_heap(), pop_heap() and sort_heap() functions. Each of these sorting functions has its own characteristics and can meet different sorting needs. In actual programming, it is very important to choose the appropriate sorting function according to the specific situation.
The above is the detailed content of Detailed explanation of sorting function in C++. For more information, please follow other related articles on the PHP Chinese website!

C++是一种广泛使用的面向对象的计算机编程语言,它支持您与之交互的大多数应用程序和网站。你需要编译器和集成开发环境来开发C++应用程序,既然你在这里,我猜你正在寻找一个。我们将在本文中介绍一些适用于Windows11的C++编译器的主要推荐。许多审查的编译器将主要用于C++,但也有许多通用编译器您可能想尝试。MinGW可以在Windows11上运行吗?在本文中,我们没有将MinGW作为独立编译器进行讨论,但如果讨论了某些IDE中的功能,并且是DevC++编译器的首选

在C++程序开发中,当我们声明了一个变量但是没有对其进行初始化,就会出现“变量未初始化”的报错。这种报错经常会让人感到很困惑和无从下手,因为这种错误并不像其他常见的语法错误那样具体,也不会给出特定的代码行数或者错误类型。因此,下面我们将详细介绍变量未初始化的问题,以及如何解决这个报错。一、什么是变量未初始化错误?变量未初始化是指在程序中声明了一个变量但是没有

C++是一门广受欢迎的编程语言,但是在使用过程中,经常会出现“未定义的引用”这个编译错误,给程序的开发带来了诸多麻烦。本篇文章将从出错原因和解决方法两个方面,探讨“未定义的引用”错误的解决方法。一、出错原因C++编译器在编译一个源文件时,会将它分为两个阶段:编译阶段和链接阶段。编译阶段将源文件中的源码转换为汇编代码,而链接阶段将不同的源文件合并为一个可执行文

如何优化C++开发中的文件读写性能在C++开发过程中,文件的读写操作是常见的任务之一。然而,由于文件读写是磁盘IO操作,相对于内存IO操作来说会更为耗时。为了提高程序的性能,我们需要优化文件读写操作。本文将介绍一些常见的优化技巧和建议,帮助开发者在C++文件读写过程中提高性能。使用合适的文件读写方式在C++中,文件读写可以通过多种方式实现,如C风格的文件IO

C++是一门强大的编程语言,它支持使用类模板来实现代码的复用,提高开发效率。但是在使用类模板时,可能会遭遇编译错误,其中一个比较常见的错误是“无法为类模板找到实例化”(error:cannotfindinstantiationofclasstemplate)。本文将介绍这个问题的原因以及如何解决。问题描述在使用类模板时,有时会遇到以下错误信息:e

iostream头文件包含了操作输入输出流的方法,比如读取一个文件,以流的方式读取;其作用是:让初学者有一个方便的命令行输入输出试验环境。iostream的设计初衷是提供一个可扩展的类型安全的IO机制。

C++是一种流行的编程语言,它强大而灵活,适用于各种应用程序开发。在使用C++开发应用程序时,经常需要处理各种信号。本文将介绍C++中的信号处理技巧,以帮助开发人员更好地掌握这一方面。一、信号处理的基本概念信号是一种软件中断,用于通知应用程序内部或外部事件。当特定事件发生时,操作系统会向应用程序发送信号,应用程序可以选择忽略或响应此信号。在C++中,信号可以

c++初始化数组的方法:1、先定义数组再给数组赋值,语法“数据类型 数组名[length];数组名[下标]=值;”;2、定义数组时初始化数组,语法“数据类型 数组名[length]=[值列表]”。


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

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

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

Atom editor mac version download
The most popular open source editor

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft
