찾다
백엔드 개발C++C++의 정렬 기능에 대한 자세한 설명

C++의 정렬 기능에 대한 자세한 설명

C++의 정렬 함수는 배열이나 컨테이너의 요소를 정렬하는 데 사용되는 함수 함수입니다. 정렬은 오름차순, 내림차순이 가능하며, 정수형, 부동소수점형, 문자형 등 다양한 형태의 데이터를 정렬할 수 있습니다. C++ 언어는 다양한 정렬 기능을 제공합니다. 이 기사에서는 이러한 정렬 기능의 사용법과 특징을 자세히 소개합니다.

  1. sort() 함수

sort() 함수는 C++ STL에서 가장 일반적으로 사용되는 정렬 함수 중 하나입니다. 해당 함수는 배열이나 컨테이너의 요소를 정렬하는 것입니다. sort() 함수의 기본 사용법은 다음과 같습니다.

sort(begin, end);

여기서 Begin은 배열 또는 컨테이너의 첫 번째 요소 주소이고, end는 마지막 요소의 주소 + 1이므로 end는 배열 또는 컨테이너의 빈 주소를 가리킵니다. 마지막 요소. sort() 함수는 기본적으로 오름차순으로 정렬합니다. 내림차순으로 정렬해야 하는 경우 함수 포인터나 람다 식을 세 번째 매개 변수로 전달할 수 있습니다.

다음은 sort() 함수를 사용하여 정수 배열을 정렬하는 방법을 보여주는 샘플 코드입니다.

#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;
}

위 코드를 실행한 결과는 다음과 같습니다.

1 2 3 4 5 6 7 8 9
  1. stable_sort() 함수

stable_sort () 함수와 sort( ) 함수는 유사하지만 정렬 후에도 동일한 값을 가진 요소의 상대 위치가 변경되지 않도록 보장합니다. stable_sort() 함수의 사용법은 sort() 함수와 유사하며 함수 포인터나 람다 표현식을 세 번째 매개변수로 전달할 수도 있습니다. 다음은 샘플 코드입니다.

#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;
}

위 코드를 실행한 결과는 다음과 같습니다.

1 2 3 4 5 6 7 8 9
  1. partial_sort() 함수

partial_sort() 함수는 배열이나 컨테이너의 요소를 부분적으로 정렬할 수 있습니다. 배열의 가장 작은 상위 k개 요소를 앞에 정렬합니다(또는 가장 큰 상위 k개 요소를 배열 앞에 정렬합니다). 사용법은 다음과 같습니다:

partial_sort(begin, middle, end);

여기서 시작은 배열 또는 컨테이너의 첫 번째 요소의 주소이고, 끝은 마지막 요소의 주소 + 1이며, 중간은 k번째 요소를 가리키는 반복자입니다. 부분 정렬() 함수는 처음 k개 요소의 순서만 보장하고 나머지 요소의 순서는 정의되지 않는다는 점에 유의해야 합니다. 다음은 샘플 코드입니다.

#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;
}

위 코드를 실행한 결과는 다음과 같습니다.

1 2 3
  1. nth_element() 함수

nth_element() 함수는 k번째로 작은(또는 k번째로 큰) 요소를 선택하는 데 사용됩니다. 배열 또는 컨테이너를 배열의 k번째 위치에 배열합니다. 사용법은 다음과 같습니다:

nth_element(begin, middle, end);

여기서 시작은 배열 또는 컨테이너의 첫 번째 요소의 주소이고, 끝은 마지막 요소의 주소 + 1이며, 중간은 k번째 요소를 가리키는 반복자입니다. nth_element() 함수는 배열의 처음 k개 요소의 순서만 보장하고 k번째 요소는 정렬되지 않음을 보장한다는 점에 유의해야 합니다. 다음은 샘플 코드입니다.

#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;
}

위 코드를 실행한 결과는 다음과 같습니다.

第 3 小的数是:3
  1. make_heap() 함수

make_heap() 함수는 배열이나 컨테이너를 힙으로 변환할 수 있습니다. 배열의 요소는 힙 작업을 지원하도록 정렬된 이진 힙 규칙을 따릅니다. 사용법은 다음과 같습니다:

make_heap(begin, end);

여기서 Begin은 배열 또는 컨테이너의 첫 번째 요소 주소이고 end는 마지막 요소의 주소 + 1입니다. 다음은 샘플 코드입니다.

#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;
}

위 코드를 실행한 결과는 다음과 같습니다.

9 7 8 6 4 3 5 1 2
  1. push_heap() 함수

push_heap() 함수는 힙에 새 요소를 삽입하고 구조를 다시 조정할 수 있습니다. 힙 특성을 만족시키는 힙입니다. 사용법은 다음과 같습니다.

push_heap(begin, end);

여기서 시작은 배열 또는 컨테이너의 첫 번째 요소 주소이고 end는 마지막 요소의 주소입니다. 삽입된 새 요소는 힙의 마지막 위치에 배치되어야 한다는 점에 유의하세요. 다음은 샘플 코드입니다.

#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;
}

위 코드를 실행한 결과는 다음과 같습니다.

9 7 8 6 4 3 5 1 2 0
  1. pop_heap() 함수

pop_heap() 함수는 힙의 최상위 요소를 팝하고 다시 조정하는 데 사용됩니다. 힙의 성격에 맞는 힙의 구조. 사용법은 다음과 같습니다.

pop_heap(begin, end);

여기서 시작은 배열 또는 컨테이너의 첫 번째 요소 주소이고 끝은 마지막 요소의 주소입니다. 힙의 최상위 요소를 팝한 후에는 힙의 크기가 1만큼 줄어들어야 합니다. 다음은 샘플 코드입니다.

#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;
}

위 코드를 실행한 결과는 다음과 같습니다.

8 7 5 6 4 3 2 1
  1. sort_heap() 함수

sort_heap() 함수는 힙을 정렬하고 정렬된 배열이 있는지 확인하는 데 사용됩니다. 오름차순. 사용법은 다음과 같습니다.

sort_heap(begin, end);

여기서 시작은 배열 또는 컨테이너의 첫 번째 요소 주소이고 끝은 마지막 요소의 주소입니다. sort_heap() 함수는 힙을 정렬하기 전에 먼저 pop_heap() 함수를 호출하여 힙의 최상위 요소를 팝하므로 정렬된 배열의 크기를 1만큼 줄여야 합니다. 다음은 샘플 코드입니다.

#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;
}

위 코드를 실행한 결과는 다음과 같습니다.

1 2 3 4 5 6 7 8 9

Summary

이 글에서는 sort(), stable_sort(), 부분 정렬() 등 C++에서 흔히 사용되는 정렬 함수를 자세히 소개합니다. ), nth_element(), make_heap(), push_heap(), pop_heap() 및 sort_heap() 함수. 이러한 각 정렬 기능은 고유한 특성을 가지며 다양한 정렬 요구 사항을 충족할 수 있습니다. 실제 프로그래밍에서는 특정 상황에 따라 적절한 정렬 기능을 선택하는 것이 매우 중요합니다.

위 내용은 C++의 정렬 기능에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
Windows 11 系统下的五款最佳免费 C++ 编译器推荐Windows 11 系统下的五款最佳免费 C++ 编译器推荐Apr 23, 2023 am 08:52 AM

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

C++报错:变量未初始化,应该如何解决?C++报错:变量未初始化,应该如何解决?Aug 21, 2023 pm 10:01 PM

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

C++编译错误:未定义的引用,该怎么解决?C++编译错误:未定义的引用,该怎么解决?Aug 21, 2023 pm 08:52 PM

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

如何优化C++开发中的文件读写性能如何优化C++开发中的文件读写性能Aug 21, 2023 pm 10:13 PM

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

C++编译错误:无法为类模板找到实例化,应该怎么解决?C++编译错误:无法为类模板找到实例化,应该怎么解决?Aug 21, 2023 pm 08:33 PM

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

iostream头文件的作用是什么iostream头文件的作用是什么Mar 25, 2021 pm 03:45 PM

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

c++数组怎么初始化c++数组怎么初始化Oct 15, 2021 pm 02:09 PM

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

C++中的信号处理技巧C++中的信号处理技巧Aug 21, 2023 pm 10:01 PM

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

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경