C++의 일반적인 정렬 알고리즘을 마스터하세요.
C++는 컴퓨터 프로그래밍에서 널리 사용되는 프로그래밍 언어이며, 정렬 알고리즘은 프로그래밍에서 일반적으로 사용되는 알고리즘 중 하나입니다. 정렬 알고리즘을 익히면 효율적인 프로그램 작성 능력을 향상하고 프로그래밍 기술을 향상시킬 수 있습니다. 이 기사에서는 C++에서 일반적으로 사용되는 정렬 알고리즘을 소개합니다.
- 버블 정렬
버블 정렬은 인접한 요소를 순서대로 비교하고 더 큰 요소를 순서의 끝 부분으로 교환하여 정렬을 수행하는 기본 정렬 알고리즘입니다. 특히 버블 정렬은 각 라운드에서 인접한 요소의 크기를 비교하고 마지막 요소가 정렬될 때까지 더 큰 요소를 뒤로 바꿉니다.
C++ 코드는 다음과 같습니다.
void bubbleSort(int arr[], int n) { for (int i = 0; i < n - 1; i++) { for (int j = 0; j < n - i - 1; j++) { if (arr[j] > arr[j+1]) { // 交换元素 int temp = arr[j]; arr[j] = arr[j+1]; arr[j+1] = temp; } } } }
- 선택 정렬
선택 정렬은 정렬되지 않은 부분에서 가장 작은 요소를 매번 선택하여 정렬된 부분의 마지막에 배치하는 간단한 정렬 알고리즘입니다. 정렬. 구체적으로 선택 정렬은 각 라운드에서 가장 작은 요소를 선택하여 현재 위치의 요소와 교환합니다.
C++ 코드는 다음과 같습니다.
void selectionSort(int arr[], int n) { int minIndex, temp; for (int i = 0; i < n - 1; i++) { minIndex = i; // 记录最小元素的位置 for (int j = i + 1; j < n; j++) { if (arr[j] < arr[minIndex]) { // 更新最小元素的位置 minIndex = j; } } // 交换元素 temp = arr[i]; arr[i] = arr[minIndex]; arr[minIndex] = temp; } }
- 삽입 정렬
삽입 정렬은 이미 정렬된 시퀀스에 요소를 삽입하여 더 긴 정렬 시퀀스를 얻는 간단하고 직관적인 정렬 알고리즘입니다. 특히, 삽입 정렬의 각 라운드는 정렬된 하위 배열에 요소를 삽입하고 나머지 요소를 뒤로 이동합니다.
C++ 코드는 다음과 같습니다.
void insertionSort(int arr[], int n) { int key, j; for (int i = 1; i < n; i++) { key = arr[i]; // 待插入的元素 j = i - 1; // 将大于待插入元素的元素向后移动 while (j >= 0 && arr[j] > key) { arr[j+1] = arr[j]; j--; } // 将待插入元素插入到正确的位置 arr[j+1] = key; } }
- 빠른 정렬
빠른 정렬은 효율적인 정렬 알고리즘입니다. 피벗 요소를 선택하여 시퀀스를 두 부분으로 분할합니다. 한 부분은 피벗 요소보다 작습니다. 다른 부분은 피벗 요소보다 크고 두 하위 시퀀스를 재귀적으로 정렬합니다. 구체적으로 말하면, 퀵 정렬은 각 라운드에서 피벗 요소를 선택하고 피벗 요소보다 작은 요소를 피벗 요소 왼쪽에 배치하고 피벗 요소보다 큰 요소를 오른쪽에 배치합니다. 그런 다음 왼쪽 및 오른쪽 하위 시퀀스가 동일한 방식으로 재귀적으로 정렬됩니다.
C++ 코드는 다음과 같습니다.
void quickSort(int arr[], int left, int right) { int i = left, j = right; int pivot = arr[(left + right) / 2]; // 选择枢纽元素 while (i <= j) { // 找到左侧大于枢纽元素的元素 while (arr[i] < pivot) { i++; } // 找到右侧小于枢纽元素的元素 while (arr[j] > pivot) { j--; } // 交换左右元素 if (i <= j) { int temp = arr[i]; arr[i] = arr[j]; arr[j] = temp; i++; j--; } } // 递归排序左侧和右侧的子序列 if (left < j) { quickSort(arr, left, j); } if (i < right) { quickSort(arr, i, right); } }
- Merge sort
Merge sort는 시퀀스를 두 개의 하위 시퀀스로 나누고 각 하위 시퀀스를 별도로 정렬한 다음 마지막으로 두 하위 시퀀스를 병합하는 정렬 알고리즘입니다. . 특히 병합 정렬은 먼저 시퀀스를 두 개의 하위 시퀀스로 분할하고 두 개의 하위 시퀀스를 재귀적으로 정렬한 다음 두 개의 정렬된 하위 시퀀스를 하나의 정렬된 시퀀스로 병합합니다.
C++ 코드는 다음과 같습니다.
void merge(int arr[], int left, int mid, int right) { int i, j, k; int n1 = mid - left + 1; int n2 = right - mid; int L[n1], R[n2]; // 将数据拷贝到两个临时数组中 for (i = 0; i < n1; i++) L[i] = arr[left + i]; for (j = 0; j < n2; j++) R[j] = arr[mid + 1 + j]; i = 0; // 左侧子数组的索引 j = 0; // 右侧子数组的索引 k = left; // 合并后的数组的索引 while (i < n1 && j < n2) { if (L[i] <= R[j]) { arr[k] = L[i]; i++; } else { arr[k] = R[j]; j++; } k++; } // 将左侧子数组的剩余元素拷贝到合并后的数组中 while (i < n1) { arr[k] = L[i]; i++; k++; } // 将右侧子数组的剩余元素拷贝到合并后的数组中 while (j < n2) { arr[k] = R[j]; j++; k++; } } void mergeSort(int arr[], int left, int right) { if (left < right) { int mid = left + (right - left) / 2; // 递归排序左侧和右侧的子序列 mergeSort(arr, left, mid); mergeSort(arr, mid + 1, right); // 合并两个有序子数组 merge(arr, left, mid, right); } }
위는 C++에서 일반적으로 사용되는 5가지 정렬 알고리즘입니다. 알고리즘은 지루해 보일 수도 있지만 정렬 알고리즘을 학습하면 프로그래밍의 효율성과 품질을 향상시킬 수 있는 중요한 부분입니다.
위 내용은 C++의 일반적인 정렬 알고리즘을 마스터하세요.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











C 언어 데이터 구조 : 트리 및 그래프의 데이터 표현은 노드로 구성된 계층 적 데이터 구조입니다. 각 노드에는 데이터 요소와 하위 노드에 대한 포인터가 포함되어 있습니다. 이진 트리는 특별한 유형의 트리입니다. 각 노드에는 최대 두 개의 자식 노드가 있습니다. 데이터는 structtreenode {intdata; structtreenode*왼쪽; structReenode*오른쪽;}을 나타냅니다. 작업은 트리 트래버스 트리 (사전 조정, 인 순서 및 나중에 순서) 검색 트리 삽입 노드 삭제 노드 그래프는 요소가 정점 인 데이터 구조 모음이며 이웃을 나타내는 오른쪽 또는 무의미한 데이터로 모서리를 통해 연결할 수 있습니다.

이 기사에서는 컨테이너, 반복자, 알고리즘 및 함수 인 핵심 구성 요소에 중점을 둔 C 표준 템플릿 라이브러리 (STL)에 대해 설명합니다. 일반적인 프로그래밍을 가능하게하기 위해 이러한 상호 작용, 코드 효율성 및 가독성 개선 방법에 대해 자세히 설명합니다.

이 기사는 효율적인 STL 알고리즘 사용을 자세히 설명합니다. 데이터 구조 선택 (벡터 대 목록), 알고리즘 복잡성 분석 (예 : std :: sort vs. std :: partial_sort), 반복자 사용 및 병렬 실행을 강조합니다. 일반적인 함정과 같은

이 기사는 C에서 효과적인 예외 처리를 자세히 설명하고, 시도, 캐치 및 던지기 메커니즘을 다룹니다. RAII와 같은 모범 사례, 불필요한 캐치 블록을 피하고 강력한 코드에 대한 예외를 기록합니다. 이 기사는 또한 Perf를 다룹니다

기사는 Move Semantics, Perfect Forwarding 및 Resource Management에 대한 C에서 RValue 참조의 효과적인 사용에 대해 논의하여 모범 사례 및 성능 향상을 강조합니다 (159 자).

파일 작동 문제에 대한 진실 : 파일 개방이 실패 : 불충분 한 권한, 잘못된 경로 및 파일이 점유 된 파일. 데이터 쓰기 실패 : 버퍼가 가득 차고 파일을 쓸 수 없으며 디스크 공간이 불충분합니다. 기타 FAQ : 파일이 느리게 이동, 잘못된 텍스트 파일 인코딩 및 이진 파일 읽기 오류.

C 20 범위는 표현성, 합성 가능성 및 효율성으로 데이터 조작을 향상시킵니다. 더 나은 성능과 유지 관리를 위해 복잡한 변환을 단순화하고 기존 코드베이스에 통합합니다.

이 기사는 C의 동적 파견, 성능 비용 및 최적화 전략에 대해 설명합니다. 동적 파견이 성능에 영향을 미치는 시나리오를 강조하고이를 정적 파견과 비교하여 성능과 성능 간의 트레이드 오프를 강조합니다.
